Android原生方法和Web JS互相调用-两种写法

 

目录

 

准备工作

 两种写法


 

 

准备工作

准备一个html文件(htmltest.html),为了简化,直接放到项目的assets目录下调用

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html40/strict.dtd">
<HTML>
<HEAD>
    <meta name="viewport" content="width=device-width, target-densitydpi=device-dpi"/>
    <META http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <script>
function showMsg(ids){
alert("hello world!"+ids);
}
function showMsgInAndroid(){
myjs.showMsg('hello in android!');
}

    </script>
</HEAD>
<BODY>
<span>测试js使用</span>

<button id='btntest' onclick='showMsgInAndroid()'>调用android方法</button>
</BODY>
</HTML>
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    android:id="@+id/rl_main"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    xmlns:android="http://schemas.android.com/apk/res/android"
    >
    <WebView
        android:id="@+id/wv_test"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:layout_above="@+id/btn_showmsg"/>
    <Button
        android:id="@+id/btn_showmsg"
        android:layout_width="200dip"
        android:layout_height="40dip"
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:text="调用html中js方法"/>
</RelativeLayout>

 两种写法

注意:开放给JavaScript调用的方法必须添加@JavascriptInterface注解,在 JELLY_BEAN/API 16/4.1开始必须添加,否则JavaScript无法调用到这个接口

public class NormalHtmlActivity extends BaseActivity {

    WebView wv_webview;
    private Button btnShowInfo;
    private AndroidtoJs js;
    private Handler mHandler = new Handler();

    @SuppressLint({"JavascriptInterface", "SetJavaScriptEnabled"})
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.layout_normal_web);
        wv_webview = findViewById(R.id.wv_test);
        btnShowInfo = (Button) findViewById(R.id.btn_showmsg);
        //实例化js对象
        js = new AndroidtoJs(this);
        //设置参数
        wv_webview.getSettings().setBuiltInZoomControls(true);
        //内容的渲染需要webviewChromClient去实现,设置webviewChromClient基类,解决js中alert不弹出的问题和其他内容渲染问题
        wv_webview.setWebChromeClient(new WebChromeClient());
        // 启用javascript
        wv_webview.getSettings().setJavaScriptEnabled(true);
       //第一种方式
        wv_webview.addJavascriptInterface(this, "myjs");
       // 第二种方式       
      //  wv_webview.addJavascriptInterface(js, "myjs");
      
        wv_webview.loadUrl("file:///android_asset/htmltest.html");
        btnShowInfo.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                mHandler.post(new Runnable() {
                    @Override
                    public void run() {
                        //调用 HTML 中的javaScript 函数
                        wv_webview.loadUrl("javascript:showMsg('原生调用JS')");
                    }
                });
            }
        });

    }

    //由于安全原因 需要加 @JavascriptInterface
    @JavascriptInterface
    public void showMsg(String msg) {
        Toast.makeText(NormalHtmlActivity.this, "JS调用HTML" + msg, Toast.LENGTH_SHORT).show();
    }

}

 

public class AndroidtoJs {

    private NormalHtmlActivity ma;

    public AndroidtoJs(NormalHtmlActivity context) {
        this.ma = context;
    }

    @JavascriptInterface
    public void showMsg(String msg) {
        Toast.makeText(ma, msg, Toast.LENGTH_SHORT).show();
    }

}

特别注意:

       1.JS执行的代码不在Android的UI线程中,是在WebView Core的线程中,所以JS调用Android的接口中,需要添加到Activity.runOnUiThread中

      2.JS调用Android方法,一定要一致,要么都带参数,要么都不传参数

      3.Android 调用JS方法,需要在子线程中进行,比如使用Handler,见上面代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黄毛火烧雪下

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值