转载请注明出处
        挺帅的移动开发专栏  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 plaincopy print?
  1. // 启用javascript
  2. contentWebView.getSettings().setJavaScriptEnabled(true);
  3. // 从assets目录下面的加载html
  4. contentWebView.loadUrl("file:///android_asset/wst.html");
  5. // 无参数调用
  6. contentWebView.loadUrl("javascript:javacalljs()");

     // 启用javascriptcontentWebView.getSettings().setJavaScriptEnabled(true);// 从assets目录下面的加载htmlcontentWebView.loadUrl("file:///android_asset/wst.html");// 无参数调用contentWebView.loadUrl("javascript:javacalljs()");

功能二

webview中js调用本地java方法,这个功能实现起来稍微有点麻烦,不过也不怎么复杂,首先要对webview绑定javascriptInterface,js脚本通过这个接口来调用java代码。
[java] view plaincopy print?
  1. contentWebView.addJavascriptInterface(this, "wst");

     contentWebView.addJavascriptInterface(this, "wst");

javainterface实际就是一个普通的java类,里面是我们本地实现的java代码, 将object 传递给webview,并指定别名,这样js脚本就可以通过我们给的这个别名来调用我们的方法,在上面的代码中,this是实例化的对象,wst是这个对象在js中的别名

 
功能三
java代码调用js并传递参数
只需要在待用js函数的时候加入参数即可,下面是传递一个参数的情况,需要多个参数的时候自己拼接及行了,注意str类型在传递的时候参数要用单引号括起来

[java] view plaincopy print?
  1. mWebView.loadUrl("javascript:test('" + aa+ "')"); //aa是js的函数test()的参数

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

<div id='b'><a οnclick="window.wst.clickOnAndroid(2)">b.c</a></div>

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

这里是实例的html代码,从assert中加载,原来做项目的时候,从assert中加载的中文网页会出现乱码,解决办法就是给html指定编码。如下         
注意:Android studio需要在 main 下创建 assets文件夹 ,在 assets文件夹下创建 wst.html 文件,如下:
[html] view plaincopy print?
  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>

<html>
<head>
<meta http-equiv="Content-Type"   content="text/html;charset=gb2312">
<script type="text/javascript">
function javacalljs(){document.getElementById("content").innerHTML +=   "<br\>java调用了js函数";
}function javacalljswithargs(arg){document.getElementById("content").innerHTML +=   ("<br\>"+arg);
}</script>
</head>
<body>
this is my html <br/>
<a onClick="window.wst.startFunction()">点击调用java代码</a><br/>
<a onClick="window.wst.startFunction('hello world')" >点击调用java代码并传递参数</a>
<br/>
<div id="content">内容显示</div>
</body>
</html>

java代码 如下

[java] view plaincopy print?
  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. }

package wst.webview;import android.annotation.SuppressLint;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.webkit.WebView;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;public class MainActivity extends Activity {private WebView contentWebView = null;private TextView msgView = null;@SuppressLint("SetJavaScriptEnabled")@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.main);contentWebView = (WebView) findViewById(R.id.webview);msgView = (TextView) findViewById(R.id.msg);// 启用javascriptcontentWebView.getSettings().setJavaScriptEnabled(true);// 从assets目录下面的加载htmlcontentWebView.loadUrl("file:///android_asset/wst.html");Button button = (Button) findViewById(R.id.button);button.setOnClickListener(btnClickListener);contentWebView.addJavascriptInterface(this, "wst");}OnClickListener btnClickListener = new Button.OnClickListener() {public void onClick(View v) {// 无参数调用contentWebView.loadUrl("javascript:javacalljs()");// 传递参数调用contentWebView.loadUrl("javascript:javacalljswithargs(" + "'hello world'" + ")");}};public void startFunction() {Toast.makeText(this, "js调用了java函数", Toast.LENGTH_SHORT).show();runOnUiThread(new Runnable() {@Overridepublic void run() {msgView.setText(msgView.getText() + "\njs调用了java函数");}});}public void startFunction(final String str) {Toast.makeText(this, str, Toast.LENGTH_SHORT).show();runOnUiThread(new Runnable() {@Overridepublic void run() {msgView.setText(msgView.getText() + "\njs调用了java函数传递参数:" + str);}});}
}

布局文件

[html] view plaincopy print?
  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>

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="fill_parent"android:layout_height="fill_parent"android:orientation="vertical" ><WebViewandroid:id="@+id/webview"android:layout_width="fill_parent"android:layout_height="fill_parent"android:layout_weight="9" /><ScrollViewandroid:id="@+id/scrollView1"android:layout_width="fill_parent"android:layout_height="wrap_content" ><TextViewandroid:id="@+id/msg"android:layout_width="fill_parent"android:layout_height="fill_parent"android:text="text" /></ScrollView><Buttonandroid:id="@+id/button"android:layout_width="fill_parent"android:layout_height="wrap_content"android:layout_weight="1"android:text="java调用js函数" /></LinearLayout>

希望对大家有所帮助

资源下载地址
http://download.csdn.net/download/wangtingshuai/5106571

转载于:https://www.cnblogs.com/changyiqiang/p/6230973.html

android webview js交互 第一节 (java和js交互)相关推荐

  1. 电商项目实战第一节: CSS3+HTML5+JS 设计案例【考拉海购网站】之【顶部导航】

    文章目录 [考拉海购网站]之[顶部导航] 第一步,分析布局 第二步,建立基本的文本目录及文件 第三步,根据第一步对导航栏的分析,在html代码里面补全需要的标签 index.html文件代码 第四步, ...

  2. java web js加版本号_[Java教程]js 比较版本号(一)

    [Java教程]js 比较版本号(一) 0 2016-07-03 15:00:13 最近群了有人问如何比较版本号,我好奇的试了一下. 比较版本号,怎么办?懒人的方法是借鉴,先查网上的资料,看看有木有直 ...

  3. 【Node.js】第一章 初识Node.js

    目录 1.1 浏览器中的javascript的运行环境 1.2 Node.js 简介 1.1 浏览器中的javascript的运行环境 1. 浏览器的组成部分 2.  javascript能在浏览器执 ...

  4. 第三部分:Android 应用程序接口指南---第一节:应用程序组件---第七章 App Widgets...

    第7章 App Widgets App Widgets是一个应用程序的微型视图,可以嵌入到其他应用程序(如主屏幕)并且能够定期更新.你可以发布一个应用程序的App Widget,而这些视图称为窗口的用 ...

  5. 第一节 Java语言发展史

    Sun公司简介 Sun公司的全称 Stanford University Network ,是斯坦福大学孵化出来的后来成为高科技公司.创立后,曾经市值名列IT公司第一位.在2001年时,市值2100亿 ...

  6. 安卓手机python开发环境_使用Python开发Android应用程序:第一节 在手机上配置Python运行环境...

    本节目录: 1.下载和安装 Scripting Layer for Android (SL4A) 2.下载和安装 Python for android 3.第一个HelloWorld程序 1.下载和安 ...

  7. JS章节 第一节总结知识点

    JS章节: //    1.将JS代码写入script,类似于style //    2.编写位置可以在任意位置    默认位置在body //    3.也可以编写到外部文件    使用 <s ...

  8. 第一节 java数据类型

    java基本数据类型 1.java中数据类型分为两种:基本类型,引用类型 其中基本类型,或者叫做内置类型,是JAVA中不同于类的特殊类型. java八种数据类型在不同平台上运行,是固定字节,固定数值范 ...

  9. android js交互 数组,Android WebView —— Java 与 JavaScript 交互总结

    相比于 Native App 和 Web App,Hybrid App 凭借其迭代灵活.控制自如.多端同步的优势在应用市场上越发显得优胜,主要得力于,其将变更频繁的部分产品功能使用 H5 开发并在客户 ...

最新文章

  1. 爬虫的系统框架组成-控制器
  2. mysql转化为GaussDB,GaussDB(openGauss)宣布开源,性能超越 MySQL 与 PostgreSQL
  3. java中实现将十六进制按位取反
  4. ventory制作U盘启动盘
  5. 安卓手机玩游戏卡顿怎么解决_手机卡顿怎么办?教你3个实用解决方法,两分钟解决卡顿难题!...
  6. 安装ubuntu20.04(安装vim、gcc、VMtools、中文输入法、汉化、修改IP地址)
  7. maven怎么和ecli_Maven的配置和Eclipse中导入SpringBoot项目一些注意点
  8. PowerShell监控——监控共享打印机 获取打印记录、打印人员、打印文件等详细信息
  9. java 获取mongodb的连接数
  10. 如何在映像更改后升级docker容器
  11. mac实用小技巧分享之使Mac快速锁屏与睡眠
  12. php java node 并发,Node、PHP、Java 和 Go 服务端 I/O 性能PK
  13. 腾讯2014实习北京笔试
  14. 墨墨背单词mysql_GitHub - flymysql/WeChat-applets: 微信小程序小鸡单词
  15. webview适配(一):文件选择,相机拍照,相册选择
  16. Block-scoped declarations (let, const, function, class) not yet supported outs报错解决
  17. Win10出现“你需要权限才能执行此操作”提示的解决方法--win7w.com
  18. 常用模块(subprocess/hashlib/configparser/logging/re)
  19. 关于height:100%的简单理解
  20. (十四)c#Winform自定义控件-键盘(一)

热门文章

  1. 【opencv 学习】【常用的图像卷积核】
  2. 《scikit-learn》随机森林之深入学习
  3. 2020年需要牢记的10个深度学习Best Practices
  4. Gaussian LDA(高斯LDA)简介
  5. Java中String.split和StringUtils.split性能比较
  6. IPC--进程间通信五(信号)
  7. 北京市2021年高考适应性测试成绩查询,2021年新高考适应性考试成绩怎么查?八省联考成绩可以保留吗?...
  8. 前端实习生笔试_前端实习生面试题——HTML
  9. python没有tkinter_Python升级提示Tkinter模块找不到的解决方法
  10. java 苹果h5不能播放_H5音频不能自动播放的问题