http://my.oschina.net/u/1376187/blog/172296

项目中使用了webview显示网页,其中需要网页和native方法有交互,搜索到一篇文章,转发分享一下:

==============================================================================================================================

转载请注明出处
挺帅的移动开发专栏  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. <div id='b'><a οnclick="window.wst.clickOnAndroid(2)">b.c</a></div>

这里准备了一个实例,实现上面的功能

 
这里是实例的html代码,从assert中加载,原来做项目的时候,从assert中加载的中文网页会出现乱码,解决办法就是给html指定编码。如下
[html]  view plain copy
  1. <html>
  2. <head>
  3. <meta http-equiv="Content-Type"  content="text/html;charset=gb2312">
  4. <script type="text/javascript">
  5. function javacalljs(){
  6. document.getElementById("content").innerHTML +=
  7. "<br\>java调用了js函数";
  8. }
  9. function javacalljswithargs(arg){
  10. document.getElementById("content").innerHTML +=
  11. ("<br\>"+arg);
  12. }
  13. </script>
  14. </head>
  15. <body>
  16. this is my html <br/>
  17. <a onClick="window.wst.startFunction()">点击调用java代码</a><br/>
  18. <a onClick="window.wst.startFunction('hello world')" >点击调用java代码并传递参数</a>
  19. <br/>
  20. <div id="content">内容显示</div>
  21. </body>
  22. </html>

java代码 如下

[java]  view plain copy
  1. package wst.webview;
  2. import android.annotation.SuppressLint;
  3. import android.app.Activity;
  4. import android.os.Bundle;
  5. import android.view.View;
  6. import android.view.View.OnClickListener;
  7. import android.webkit.WebView;
  8. import android.widget.Button;
  9. import android.widget.TextView;
  10. import android.widget.Toast;
  11. public class MainActivity extends Activity {
  12. private WebView contentWebView = null;
  13. private TextView msgView = null;
  14. @SuppressLint("SetJavaScriptEnabled")
  15. @Override
  16. public void onCreate(Bundle savedInstanceState) {
  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. Button button = (Button) findViewById(R.id.button);
  26. button.setOnClickListener(btnClickListener);
  27. contentWebView.addJavascriptInterface(this, "wst");
  28. }
  29. OnClickListener btnClickListener = new Button.OnClickListener() {
  30. public void onClick(View v) {
  31. // 无参数调用
  32. contentWebView.loadUrl("javascript:javacalljs()");
  33. // 传递参数调用
  34. contentWebView.loadUrl("javascript:javacalljswithargs(" + "'hello world'" + ")");
  35. }
  36. };
  37. public void startFunction() {
  38. Toast.makeText(this, "js调用了java函数", Toast.LENGTH_SHORT).show();
  39. runOnUiThread(new Runnable() {
  40. @Override
  41. public void run() {
  42. msgView.setText(msgView.getText() + "\njs调用了java函数");
  43. }
  44. });
  45. }
  46. public void startFunction(final String str) {
  47. Toast.makeText(this, str, Toast.LENGTH_SHORT).show();
  48. runOnUiThread(new Runnable() {
  49. @Override
  50. public void run() {
  51. msgView.setText(msgView.getText() + "\njs调用了java函数传递参数:" + str);
  52. }
  53. });
  54. }
  55. }

布局文件

[html]  view plain copy
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns: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>

希望对大家有所帮助

资源下载地址

http://download.csdn.net/download/wangtingshuai/5106571

====================================================================================================================

结尾总结几句:

1、webview load网页时,native code能和网页中的js相互交互并传递参数(一个参数)。

2、js调用native code那部分一下子可能看得不是很明白,这里整理一下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
//native code方面
//使用addJavascriptInterface绑定“wst”
contentWebView.addJavascriptInterface(this, "wst");
//添加需要响应的方法,注意必须为public
public void startFunction(final String str) {  
        Toast.makeText(this"js调用了java函数", Toast.LENGTH_SHORT).show();  
        runOnUiThread(new Runnable() {  
   
            @Override  
            public void run() {  
                msgView.setText(msgView.getText() + "\njs调用了java函数");  
   
            }  
        });  
    }
//js方面
<a onClick="window.wst.startFunction('hello world')" >点击调用java代码并传递参数</a><span><span style="line-height:20px;"> </span></span>

分享到:  

转载于:https://www.cnblogs.com/qishuai/p/4522210.html

webview的javascript与Native code交互相关推荐

  1. Android WebView与JavaScript交互详解

    近期工作项目中遇到Android的WebView与js交互问题,之前也知道有这方面的技术可以实现.但在用的过程中,却发现还是需要用电心思. 现把我所了解的分享给大家,希望可以帮助到做类似项目的童鞋. ...

  2. 通过webView与javascript交互来研究webView的特点

    1.前言 webView是android中用于展示简单的网页或者加载一些html格式的很好的选择,它提供了很多的操作上的封装但同时又不失去灵活性,因为他提供了webViewClient和webChro ...

  3. Android开发笔记(一百五十一)WebView与JavaScript交互的四种形式

    WebView如果作为简单的网页浏览器,对于一般的浏览行为来说,已经足够了.可做为企业开发者,你的App通常要嵌入自家公司的网页,如此一来,还得考虑App与Web之间的消息传递,这就涉及到App的原生 ...

  4. Android WebView 和 javaScript的互相调用(三)

    原文出处:http://motalks.cn/2016/08/27/Android-WebView-JavaScript-2/ WebView相关阅读 Android WebView 和 javaSc ...

  5. Webview与Javascript

    文章目录 0x01 WebView 概述 0x02 WebView 相关工具类 2.1 WebSettings 2.2 WebViewClient 2.3 WebChromeClient 0x03 W ...

  6. 【Win7下Android native code的编译和调试】

    光为这编译及调试环境就前后折腾了两三天,墙外找了很多教程,bill以为以下教程最为贴切 Using eclipse for android - cc Development Using eclipse ...

  7. [原]iOS中 Web 页面与 Native Code 的一种通信方式

    在 iOS 开发中,Web 页面与 Native Code 通信可以分为两个方面: 1.Native Code 调用 Web 页面的方法:主要是调用页面中的 Javascript 函数. 2.Web ...

  8. Android WebView 和 javaScript的互相调用(二)

    原文出处:http://blog.csdn.net/wangtingshuai/article/details/8635787 WebView相关阅读 Android WebView 和 javaSc ...

  9. Android WebView 和 javaScript的互相调用(一)

    原文出处:http://blog.csdn.net/wangtingshuai/article/details/8631835 WebView相关阅读 Android WebView 和 javaSc ...

  10. Creating a Java VM from Android Native Code

    If you're writing native / JNI code for Android, it's probably as native method of an Android app. T ...

最新文章

  1. 【入门篇】如何正确使用机器学习中的训练集、验证集和测试集?
  2. 快速排序java代码_8 种排序算法与 Java 代码实现!
  3. IOS纯手写代码支持旋屏
  4. C++kruskals算法生成最小协议树(附完整源码)
  5. 实现当前目录下开启CMD
  6. python pygame鼠标点击_Python中pygame的mouse鼠标事件用法实例
  7. syslog 华为 服务器_删除华为云服务器自带的探针
  8. STM32 使用片外外扩内存调试
  9. ioc中最基本的JAVA技术_Spring IOC 知识点总结
  10. 哈夫曼树(二)之 C++详解
  11. ssm-学子商城-项目第十三天最后一天完成项目
  12. 库仑计DS2781通信失败
  13. 98版五笔字型实用学习教程
  14. 服务器建文件夹,服务器建立文件夹
  15. [导入]polygraph3d三维运行时引擎为silverlight 1.0.zip(15.69 KB)
  16. Golang 标准库 tips之waitgroup详解
  17. redis-狂神基础版
  18. Android定制属于你自己的导航栏
  19. 上市公司股利分红数据(1991-2020)
  20. 通过字体名获取字体文件

热门文章

  1. zendstudio 的使用过程中出现 Editor could not be initialized. 的问题
  2. SAX方式解析XML文档
  3. Multipart生成的临时文件
  4. 经典排序算法(二十二)--图书馆排序(Library Sort)
  5. 经典排序算法(九)--鸡尾酒排序Cocktail Sort
  6. 获取笔记本序列号(SN码)命令
  7. MySQL error(1449) The user specified as a definer ('usertest'@'%') does not exist
  8. 留言板删除功能mysql_用PHP写留言板代码时怎样才能实现删除和修改留言的啊?代码是怎样的?...
  9. 高性能mysql系统设计_MySQL 高性能表设计规范
  10. linux拆除模块驱动程序会跑吗,关于移植linux驱动问题,是不是还有别的办法?...