Android 网页和本地交互 JavascriptInterface

Android 端:

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment
        View view = inflater.inflate(R.layout.fragment_web_view, container, false);
        mWebView = view.findViewById(R.id.webView);
        WebSettings settings = mWebView.getSettings();
        settings.setJavaScriptEnabled(true);
        mWebView.loadUrl("file:///android_asset/test.html");
        mWebView.addJavascriptInterface(new JSInterface(),"yuge");
        //调用js 函数
        view.findViewById(R.id.js1).setOnClickListener(v -> {mWebView.loadUrl("javascript:javacalljs()");});
        String data = "test2222";
        view.findViewById(R.id.js2).setOnClickListener(v -> {mWebView.loadUrl("javascript:javacalljswith('" + data + "')");});
        return view;
    }

    static class JSInterface{
        @JavascriptInterface
        public void jsCallAndroid(){
            Log.d(TAG,"jsCallAndroid");

        }

        @JavascriptInterface
        public void jsCallAndroidArgs(String str1,String str2){
            Log.d(TAG,"jsCallAndroidWithArgs " +str1 + "_"+str2);
        }
    }

html 调用 android,android 端需要对WebView 做一些设置。
关键的代码就是

        settings.setJavaScriptEnabled(true);
        mWebView.addJavascriptInterface(new JSInterface(),"yuge");

启用增加一个Js 接口,比如我这里添加了一个接口,名字叫yuge。

网页:

<html>
<head>
    <meta http-equiv="Content-Type" charset="utf-8"/>

    <script type="text/javascript">
            function javacalljs(){
                 document.getElementById("showmsg").innerHTML = "JAVA调用了JS的无参函数";
            }

            function javacalljswith(arg){
                 document.getElementById("showmsg").innerHTML = (arg);
            }

        </script>

</head>

<body>
<h3>Web模块</h3>

<h3 id="showmsg">调用js显示结果</h3>

<input type="button" value="Js调用Java代码" onclick="window.yuge.jsCallAndroid()"/>

<input type="button" value="Js调用Java代码并传参数" onclick="window.yuge.jsCallAndroidArgs('1','2')"/>
</body>
</html>

网页端就可以直接调用window.yuge.jsCallAndroidArgs 就可以调用到Android 的代码。

总结:

不管多么简单,多么难,动手坐一坐,写一写。

参考:
https://www.jianshu.com/p/b649c3c241a6
https://blog.csdn.net/weixin_44310357/article/details/88317462

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值