(js)JavaScript调用本地android的方法

之前由于公司的一个需求:通过web网页的点击事件必须传值给android本地并且跳转到指定的页面,当时js这块我不了解,就和前端工程师研究讨论最终是做出来了,现在看来挺简单的,回顾做个记录~!

首先初始化我们的WebView,上代码:

mWeb = (WebView) findViewById(R.id.webview);

        WebSettings settings = mWeb.getSettings();
        // settings.setJavaScriptCanOpenWindowsAutomatically(true);
        settings.setJavaScriptEnabled(true);
        // settings.setSupportZoom(true);
        // settings.setBuiltInZoomControls(true);
        // settings.setUseWideViewPort(true);
        // settings.setLoadWithOverviewMode(true);
        settings.setAppCacheEnabled(true);
        settings.setDomStorageEnabled(true);
        mWeb.setWebViewClient(new WebViewClient());
        mWeb.setWebChromeClient(new WebChromeClient());
与WebView交互需要传入一个对象,以及这个对象的标记:

 mWeb.addJavascriptInterface(new JavaScriptKit(this), "android");
JavaScriptKit就是需要传给js进行交互的对象,他的代码很简单,android 是我们对这个对象的标记,可以理解为是供js进行调用的一个引用名!

/**
 * Created by chensd on 2016/12/19.
 */
public class JavaScriptKit {
    private Context context;

    public JavaScriptKit(Context context) {
        this.context = context;
    }

    @JavascriptInterface
    public void showToast(String text){
        Toast.makeText(context, text, Toast.LENGTH_LONG).show();
    }
}
这里需要注意一点,为了兼容高版本,我们需要在方法处加入@JavascriptInterface

之后调用如下load方法,加载本地静态网页:

mWeb.loadUrl("file:///android_asset/phone.html");
Html的内容比较简单,就是一个按钮,调用js的函数,通过“android”的这个标记,从而调用本地的方法!
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
	<title>Document</title>
	<style type="text/css">
		*{margin:0; padding:0;}
		.main{width: 20%; margin: 200px auto;}
	</style>
</head>
<body>
	<script type="text/javascript">
		function showToast(){
			android.showToast("来自javaScript!!");
		}
	</script>

	<div class="main">
		<form>
		<input type="button" value="这是web的按钮" οnclick="showToast()">
	</form>
	</div>
</body>
</html>
记得把html文件放在assets目录下,好了这样的简单交互就搞定了,demo地址如下:

https://github.com/chenshandong/JavaScriptAndroidDemo




  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值