打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
JS与移动端webview的相互交互
JS与移动端webview的相互交互
  • 发布时间: 2016/02/19 13:05
  • 阅读: 1552
  • 收藏: 23
  • 点赞: 4
  • 评论: 3
摘要
以android移动端为例

随着h5在移动端的普及,移动端对webview的使用越来越平凡,有的界面也不仅仅局限于网页的显示,很多时候就要涉及到webview与javascript代码之间的交互,这对于移动端工程师和web端工程师都是一个挑战,下面来总结下它们之间的交互和注意事项。

1.先说js中调用android代码:下面是我写的一段简单的js代码:放在了assets文件夹下了(注意若使用的是AS这个IDE,assets文件夹应放在src/main目录下)

<!DOCTYPE html><html>   <head>      <meta charset="utf-8">      <title>葛夫锋</title>            <script>         function callAndroid(){            test.hello("js调用了android中的hello方法");         }      </script>   </head>   <body>      <button type="button" id="button1" onclick="callAndroid()">js调用android中的代码</button>   </body></html>

代码非常简单,页面中就一个按钮,点击这个按钮调用callAndroid函数,这里需注意callAndroid函数中的语句是android中对外的的一个函数,在android中的代码:

{    ...       webSettings.setJavaScriptEnabled(true);    webView.addJavascriptInterface(this, "test");//对应js中的test.xxx    webView.loadUrl("file:///android_asset/js_web.html");}@JavascriptInterfacepublic void hello(String msg){//对应js中xxx.hello("")    Log.e("webview","hello");    Toast.makeText(this,msg,Toast.LENGTH_LONG).show();}

这里需注意的是hello函数加上注解@javascriptInterface,这样点击html中的按钮就会调用android中的hello方法了。

2.android调用js代码:

js代码如下:

<script>   function callJS(){      alert("android调用了js中的callJS方法");   }</script>

android代码如下:

public void click(View view){    webView.post(new Runnable() {        @Override        public void run() {            webView.loadUrl("javascript:callJS()");        }    });}

当android中的按钮被点击时会触发click方法,然后执行webview.loadUrl("javascript:callJS()"),然后js中正好有callJS这个方法,然后alert()就会被执行,这里需要注意的是在android的代码中我没有直接写

webView.loadUrl("javascript:callJS()");

而是加了一个post(new Runble),若不加的话js代码是不被调用的。

好了,是不是so easy,android与js的简单交互就是这样,欢迎补充

著作权归作者所有

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
Hybrid APP之Native和H5页面交互原理
Android WebView的使用
【Android】webview javascript 注入方法
Android开发之WebView知识和常见问题
Android极简的js与java交互库一一SimpleJavaJsBridge
Android与HTML-JS交互入门
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服