您当前的位置:首页 > 互联网教程

怎么实现javascript中调用java类中的方法

发布时间:2025-05-24 11:23:01    发布人:远客网络

怎么实现javascript中调用java类中的方法

一、怎么实现javascript中调用java类中的方法

为了方便网页和Android应用的交互,Android系统提供了WebView中JavaScript网页脚本调用Java类方法的机制。只要调用addJavascriptInterface方法即可映射一个Java对象到JavaScript对象上。

1、映射Java对象到JavaScript对象上

mWebView=(WebView) findViewById(R.id.wv_content);

mWebView.setVerticalScrollbarOverlay(true);

final WebSettings settings= mWebView.getSettings();

settings.setSupportZoom(true);

//WebView启用Javascript脚本执行

settings.setJavaScriptEnabled(true);

settings.setJavaScriptCanOpenWindowsAutomatically(true);

//映射Java对象到一个名为”js2java“的Javascript对象上

//JavaScript中可以通过"window.js2java"来调用Java对象的方法

mWebView.addJavascriptInterface(new JSInvokeClass(),"js2java");

调用上述JSInvokeClass类对象的back方法,如下:

二、 标签调用js的几种方法

我们常用的在a标签中有点击事件:

a href="javascript:js_method();"

这是我们平台上常用的方法,但是这种方法在传递this等参数的时候很容易出问题,而且javascript:协议作为a的href属性的时候不仅会导致不必要的触发window.onbeforeunload事件,在IE里面更会使gif动画图片停止播放。W3C标准不推荐在href里面执行javascript语句

2. a href="javascript:void(0);" onclick="js_method()"

这种方法是很多网站最常用的方法,也是最周全的方法,onclick方法负责执行js函数,而void是一个操作符,void(0)返回undefined,地址不发生跳转。而且这种方法不会像第一种方法一样直接将js方法暴露在浏览器的状态栏。

3.a href="javascript:;" onclick="js_method()"

这种方法跟跟2种类似,区别只是执行了一条空的js代码。

4.a href="#" onclick="js_method()"

这种方法也是网上很常见的代码,#是标签内置的一个方法,代表top的作用。所以用这种方法点击后网页后返回到页面的最顶端。

5.a href="#" onclick="js_method();return false;"

这种方法点击执行了js函数后return false,页面不发生跳转,执行后还是在页面的当前位置。

我看了下taobao的主页,他们采用的是第2种方法,而alibaba的主页是采用的第1种方法,和我们的区别是每个href里的javascript方法都用try、catch包围。

综合上述,在a中调用js函数最适当的方法推荐使用:

a href="javascript:void(0);" onclick="js_method()"

a href="javascript:;" onclick="js_method()"

a href="#" onclick="js_method();return false;"

三、如何在js函数中调用另外一个函数

1、具体调用情况需要看js方法是怎么写的。

2、①如果是最简单的一个方法:functiuon dome1(){//.代码块}//调用方法就是:dome1()。

3、②如果是闭包形式:function dome1(){ function dome2(){} return function dome3(){}}//这里可以访问dome1方法内的dome3方法,dome2方法对与dome1方法外部是不可见的。

4、③如果是一个对象形式的:var obj={ dome1:function(key,value){}, dome2:function(){}};//访问dome1和dome2方法:obj.dome1(1,2);obj.dome2()。

5、函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块。JavaScript函数语法,函数就是包裹在花括号中的代码块,前面使用了关键词 function:当调用该函数时,会执行函数内的代码。

6、可以在某事件发生时直接调用函数(比如当用户点击按钮时),并且可由 JavaScript在任何位置进行调用。

7、function函数名(var1, var2,..., varX){代码...}

8、function函数名(var1, var2,..., varX){代码...}

9、var1, var2等指的是传入函数的变量或值。{和}定义了函数的开始和结束。

10、注意:无参数的函数必须在其函数名后加括号:

11、注意:别忘记 JavaScript中大小写字母的重要性。"function"这个词必须是小写的,否则 JavaScript就会出错。另外需要注意的是,必须使用大小写完全相同的函数名来调用函数。

12、参考资料:百度百科——JavaScript函数