webview的javascript与Native code交互

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 onclick="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>

分享到: 

时间: 2024-10-07 23:01:49

webview的javascript与Native code交互的相关文章

cordova与ios native code交互的原理

非常早曾经写了一篇博客,总结cordova插件怎么调用到原生代码:cordova调用过程,只是写得太水.基本没有提到原理.近期加深了一点理解,又一次补充说明一下 js调用native 以下是我们产品中的代码片段: datePicker.show(options, function (date) { var month = date.getMonth() + 1; callback(null, date.getFullYear() + "-" + month + "-"

Android中WebView的JavaScript代码和本地代码交互的三种方式

一.Android中WebView的漏洞分析 最近在开发过程中遇到一个问题,就是WebView使用的时候,还是需要解决之前系统(4.2之前)导致的一个漏洞,虽然现在这个系统版本用户很少了,但是也不能忽视,关于这个漏洞,这里就不多做解释了,可能有的同学早就了解了,本来想写一篇文章详细介绍一下,但是网上的知识太多了,而且都很详细,就没弄了,这里大致简单明了的说几句: 第一.漏洞产生的原因 这个漏洞导致的原因主要是因为Android中WebView中的JS访问本地方法的方式存在缺陷,我们做过交互的都知

Hybrid----优秀开源代码解读之JS与iOS Native Code互调的优雅实现方案-备

本篇为大家介绍一个优秀的开源小项目:WebViewJavascriptBridge. 它优雅地实现了在使用UIWebView时JS与ios 的ObjC nativecode之间的互调,支持消息发送.接收.消息处理器的注册与调用以及设置消息处理的回调. 就像项目的名称一样,它是连接UIWebView和Javascript的bridge.在加入这个项目之后,他们之间的交互处理方式变得很友好. 在native code中跟UIWebView中的js交互的时候,像下面这样: [cpp] view pla

优秀开源代码解读之JS与iOS Native Code互调的优雅实现方案

简介 本篇为大家介绍一个优秀的开源小项目:WebViewJavascriptBridge. 它优雅地实现了在使用UIWebView时JS与ios 的ObjC nativecode之间的互调,支持消息发送.接收.消息处理器的注册与调用以及设置消息处理的回调. 就像项目的名称一样,它是连接UIWebView和Javascript的bridge.在加入这个项目之后,他们之间的交互处理方式变得很友好. 在native code中跟UIWebView中的js交互的时候,像下面这样: [cpp] view

WebViewJavascriptBridge JS与iOS Native Code互调方法

本篇为大家介绍一个优秀的国人开发开源小项目:WebViewJavascriptBridge. 下载WebViewJavascriptBridge地址 它优雅地实现了在使用UIWebView时JS与ios 的Objective-C nativecode之间的互调,支持消息发送.接收.消息处理器的注册与调用以及设置消息处理的回调. 就像项目的名称一样,它是连接UIWebView和Javascript的bridge.在加入这个项目之后,他们之间的交互处理方式变得很友好. 在native code中跟U

Android Webview 和Javascript交互,实现Android和JavaScript相互调用

在Android的开发过程中.遇到一个新需求.那就是让Java代码和Javascript代码进行交互.在IOS中实现起来很麻烦.而在Android中相对来说容易多了.Android对这种交互进行了很好的封装.我们可以很简单的用Java代码调用WebView中的js函数.也可以用WebView中的js来调用Android应用中的Java代码. 案例主要包含了: Html中调用Android方法 Android调用JS方法无参数 Android调用JS方法有参数 Android调用JS方法有参数且有

Android WebView与JavaScript交互操作(Demo)

应用场景: 为了使Android移动项目能够在较短的时间内完成开发,同时降低技术人员开发的成本投入,往往会采用Hybrid APP的开发模式.相关Hybrid APP(混合型应用)参看:http://blog.csdn.net/mahoking/article/details/30235243 采用这种模式,为了解决更好的用户体验,可访问本地资源的能力.势必需要了解与掌握Android(java)与JavaScript之间的交互.相互调用操作的方法与技术. [转载使用,请注明出处:http://

Android WebView与JavaScript交互实现Web App

当我们去开发一个基于web的android app时,我们第一须要处理的就是与JavaScript的交互问题.Android须要做的事情就是开放某些特定的接口供web里的JavaScript调用,能够开放弹出框功能,Toast,界面跳转等等.这样我们的web视图以假乱真的当成Android的原生界面.而这套web代码又能够嵌入iPhone的client中.也就是说Android和IOSclient不过提供一个共web使用的框架,业务都由web端处理.这岂不是开发一次.可处处执行.然而这一切都是后

IOS下WEBVIEW 的javascript数组与json定义 及交互

最近在折腾IOS新闻浏览客户端,当中需要用到webview传递JSON数据到IOS上,然后在IOS上解析.刚入门IOS不久,看了不少的书,但都是囫囵吞枣.在开发过程中,遇到不少问题.开发环境mac mini (IOS端开发)thinkpad x200s(PHP开发)功能实现:在WEBVIEW创建DOM监听,判断用户按下WEBVIEW上链接,通过DOM获取相关链接信息,遍历数组,最终用$.toJSON(jsArray);//将JS数组转换成JSON格式下面记录一下1.JS数组定义最终在WEBVIE