转于:http://blog.csdn.net/wangtingshuai/article/details/8631835

--------------------------------------------------------------------------------------------------------------------

在android的开发过程中,有很多时候需要用到本地java代码和javascript进行交互。android对交互进行了很好的封装,在开发中我们可以很简单的用java代码调用webview中的js,也可以用webview中的js来调用本地的java代码,这样我们可以实现很多原来做不了的功能,比如点击网页上的电话号码后,手机自动拨打电话,点击网页中的笑话,自动发送短信等.

废话不多说,这次教程的目标如下
  1. android 中的java代码调用webview里面的js脚本
  2. webview中的js脚本调用本地的java代码
  3. java调用js并传递参数
  4. js调用java并传递参数
功能一 android中调用webview中的js脚本非常方便,只需要调用webview的loadUrl方法即可( 注意开启js支持[html] view plain copy
  1. //启用javascript
  2. contentWebView.getSettings().setJavaScriptEnabled(true);
  3. //从assets目录下面的加载html
  4. contentWebView.loadUrl("file:///android_asset/wst.html");
  5. //无参数调用
  6. contentWebView.loadUrl("javascript:javacalljs()");
功能二
webview中js调用本地java方法,这个功能实现起来稍微有点麻烦,不过也不怎么复杂, 首先要对webview绑定javascriptInterface,js脚本通过这个接口来调用java代码。 [java] view plain copy
  1. contentWebView.addJavascriptInterface(this,"wst");
javainterface实际就是一个普通的java类,里面是我们本地实现的java代码, 将object 传递给webview,并指定别名,这样js脚本就可以通过我们给的这个别名来调用我们的方法,在上面的代码中, this是实例化的对象,wst是这个对象在js中的别名
功能三
java代码调用js并传递参数
只需要在待用js函数的时候加入参数即可,下面是传递一个参数的情况,需要多个参数的时候自己拼接及行了,注意str类型在传递的时候参数要用单引号括起来

[java] view plain copy
  1. mWebView.loadUrl("javascript:test('"+aa+"')");//aa是js的函数test()的参数
功能四
js调用java函数并传参,java函数正常书写,在js脚本中调用的时候稍加注意
然后在html页面中,利用如下代码,即可实现调用 [html] view plain copy
  1. <divid='b'><aonclick="window.wst.clickOnAndroid(2)">b.c</a></div>

这里准备了一个实例,实现上面的功能 android webview js交互 (java和js交互) 这里是实例的html代码,从assert中加载,原来做项目的时候,从assert中加载的中文网页会出现乱码,解决办法就是给html指定编码。如下
[html] view plain copy
  1. <html>
  2. <head>
  3. <metahttp-equiv="Content-Type"content="text/html;charset=gb2312">
  4. <scripttype="text/javascript">
  5. functionjavacalljs(){
  6. document.getElementById("content").innerHTML+=
  7. "<br\>java调用了js函数";
  8. }
  9. functionjavacalljswithargs(arg){
  10. document.getElementById("content").innerHTML+=
  11. ("<br\>"+arg);
  12. }
  13. </script>
  14. </head>
  15. <body>
  16. thisismyhtml<br/>
  17. <aonClick="window.wst.startFunction()">点击调用java代码</a><br/>
  18. <aonClick="window.wst.startFunction('helloworld')">点击调用java代码并传递参数</a>
  19. <br/>
  20. <divid="content">内容显示</div>
  21. </body>
  22. </html>

java代码 如下
[java] view plain copy
  1. packagewst.webview;
  2. importandroid.annotation.SuppressLint;
  3. importandroid.app.Activity;
  4. importandroid.os.Bundle;
  5. importandroid.view.View;
  6. importandroid.view.View.OnClickListener;
  7. importandroid.webkit.WebView;
  8. importandroid.widget.Button;
  9. importandroid.widget.TextView;
  10. importandroid.widget.Toast;
  11. publicclassMainActivityextendsActivity{
  12. privateWebViewcontentWebView=null;
  13. privateTextViewmsgView=null;
  14. @SuppressLint("SetJavaScriptEnabled")
  15. @Override
  16. publicvoidonCreate(BundlesavedInstanceState){
  17. super.onCreate(savedInstanceState);
  18. setContentView(R.layout.main);
  19. contentWebView=(WebView)findViewById(R.id.webview);
  20. msgView=(TextView)findViewById(R.id.msg);
  21. //启用javascript
  22. contentWebView.getSettings().setJavaScriptEnabled(true);
  23. //从assets目录下面的加载html
  24. contentWebView.loadUrl("file:///android_asset/wst.html");
  25. Buttonbutton=(Button)findViewById(R.id.button);
  26. button.setOnClickListener(btnClickListener);
  27. contentWebView.addJavascriptInterface(this,"wst");
  28. }
  29. OnClickListenerbtnClickListener=newButton.OnClickListener(){
  30. publicvoidonClick(Viewv){
  31. //无参数调用
  32. contentWebView.loadUrl("javascript:javacalljs()");
  33. //传递参数调用
  34. contentWebView.loadUrl("javascript:javacalljswithargs("+"'helloworld'"+")");
  35. }
  36. };
  37. publicvoidstartFunction(){
  38. Toast.makeText(this,"js调用了java函数",Toast.LENGTH_SHORT).show();
  39. runOnUiThread(newRunnable(){
  40. @Override
  41. publicvoidrun(){
  42. msgView.setText(msgView.getText()+"\njs调用了java函数");
  43. }
  44. });
  45. }
  46. publicvoidstartFunction(finalStringstr){
  47. Toast.makeText(this,str,Toast.LENGTH_SHORT).show();
  48. runOnUiThread(newRunnable(){
  49. @Override
  50. publicvoidrun(){
  51. msgView.setText(msgView.getText()+"\njs调用了java函数传递参数:"+str);
  52. }
  53. });
  54. }
  55. }

布局文件 [html] view plain copy
  1. <?xmlversion="1.0"encoding="utf-8"?>
  2. <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:orientation="vertical">
  6. <WebView
  7. android:id="@+id/webview"
  8. android:layout_width="fill_parent"
  9. android:layout_height="fill_parent"
  10. android:layout_weight="9"/>
  11. <ScrollView
  12. android:id="@+id/scrollView1"
  13. android:layout_width="fill_parent"
  14. android:layout_height="wrap_content">
  15. <TextView
  16. android:id="@+id/msg"
  17. android:layout_width="fill_parent"
  18. android:layout_height="fill_parent"
  19. android:text="text"/>
  20. </ScrollView>
  21. <Button
  22. android:id="@+id/button"
  23. android:layout_width="fill_parent"
  24. android:layout_height="wrap_content"
  25. android:layout_weight="1"
  26. android:text="java调用js函数"/>
  27. </LinearLayout>

更多相关文章

  1. C语言函数以及函数的使用
  2. android 代码混淆之后 微信分享不起作用
  3. Android移动操作系统源代码
  4. android_relative布局参数学习
  5. Android Studio系列(二)使用Android Studio开发/调试整个android系
  6. Android开发常用代码片段(三)
  7. Android 性能优化之Java(Android)代码优化 (三)

随机推荐

  1. Android(安卓)ApiDemos示例解析(128):Vie
  2. Android(安卓)ViewRootImpl 解析
  3. 环境搭建
  4. .Net程序员玩转Android开发---(20)Androi
  5. android窗口动画和过渡动画(activity和dia
  6. PX(像素)转换工具类
  7. Android控件之文本控件---TextView 两种
  8. 学习Android(安卓)Studio里的Gradle
  9. 设置自定义ProgressBar样式
  10. Android(安卓)布局单位转换