在Android的WebView中我们可以实现Java代码和javascript代码的互相调用,下面用一个demo说明:

1、首先是布局文件,比较简单,上面一个Button,下面一个WebView,这个就不上xml代码了

2、然后是html文件,这里测试用的是写好的html文件,放在Android工程的assets目录下,命名为test.html,其内容为:

<script language='javascript'><!-- 该方法是被Java代码调用的 -->function test(){alert('my name is yubo');}<!-- 该方法最后将调用Java代码中的showToast()方法 -->function btnclick(){client.showToast();}</script><!-- html显示文本 -->hello, world!<br/><!-- html显示按钮 --><input type="button" value="show toast" onclick="btnclick()"/>

在Activity中,主要代码如下:

package com.example.testjs;import android.os.Bundle;import android.annotation.SuppressLint;import android.app.Activity;import android.view.View;import android.webkit.WebChromeClient;import android.webkit.WebView;import android.widget.Toast;@SuppressLint("SetJavaScriptEnabled")public class MainActivity extends Activity {private WebView webView;    @Override    public void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);                webView = (WebView) findViewById(R.id.webview);        //设置WebView支持javascript        webView.getSettings().setJavaScriptEnabled(true);        //让WebView加载本地html文件        webView.loadUrl("file:///android_asset/test.html");        webView.setWebChromeClient(new WebChromeClient());        //设置WebView的js接口,通过此处的设置,让js可以调用Java代码        webView.addJavascriptInterface(this, "client");    }        //这是Activity中显示的按钮的点击事件,测试通过Java调用js方法    public void btnClick(View view){    webView.loadUrl("javascript:test()");    }        //这是将会被js调用的Java方法,当html文件中的按钮被点击时执行该方法    public void showToast(){    Toast.makeText(this, "this function is called by js", Toast.LENGTH_SHORT).show();    }}
程序运行时的界面如下:


当点击页面上方的show alert按钮时,会调用js中的方法,执行结果如下图:


当点击WebView中的show toast按钮时,将会通过js代码调用Activity中的showToast()方法,显示一个Toast,执行结果如下图:


更多相关文章

  1. android 判断横竖屏
  2. Android横竖屏切换相关总结
  3. [置顶] Android(安卓)调用js,传对象到js里面使用addJavascriptInt
  4. Android中AsyncTask的简单用法
  5. 我的Android进阶之旅------>Android中解析XML 技术详解---->SAX
  6. 实现三星S3蒲公英水波纹效果(二)——Renderscript准备篇
  7. Android(安卓)应用界面显示流程
  8. 浅谈Java中Collections.sort对List排序的两种方法
  9. Python list sort方法的具体使用

随机推荐

  1. 下一代原生应用开发框架来了:Google Flutt
  2. 盘一盘机器学习中的那些距离
  3. 世界顶级公司的前端面试都问些什么[每日
  4. 精通webpack的5大关键点
  5. 使用机器学习生成可维护的前端代码(附源
  6. 前端AI实战——告诉世界前端也能做AI
  7. 文末重磅福利|Python实现回归预测及模型优
  8. 使用 RAIL 模型评估前端性能 [每日前端夜
  9. RPA 2020.11 all in one 安装
  10. Django-bootstrap3|在Django中快速使用Boo