Android与js交互

Android与H5前端之间的js交互Demo(非常简单,通俗易

2019-08-23  本文已影响50人  嘤嘤嘤999

一、为什么要进行js交互:

为了方便原生开发和Html之间数据传递,在静态页面的情况下可以改变原生开发的页面;

二、如何进行js交互:

// 获取WebSetting对象
WebSettings webSettings = webview.getSettings();
// 设置支持javascript
webSettings.setJavaScriptEnabled(true);
// 将Android里面定义的类对象AndroidJs暴露给javascript
webview.addJavascriptInterface(new AndroidJs(MainActivity.this), "AndroidJs");
 webview.loadUrl("javascript:doAlert()");

H5端代码:

<input type="button" value="打招呼" onclick="AndroidJs.showToast()"/>
<input type="button" value="图书列表" onclick="AndroidJs.showList()"/>

Android端代码:

public class AndroidJs {
    private Context mContext;

    public AndroidJs(Context context) {
        this.mContext = context;
    }

    @JavascriptInterface  //必须有否则方法无用
    public void showList() {
        new AlertDialog.Builder(mContext)
                .setTitle("图书列表")
                .setIcon(R.mipmap.ic_launcher)
                .setItems(
                        new String[]{"疯狂java讲义", "疯狂Android讲义",
                                "轻量级java EE开发"}, null)
                .setPositiveButton("确定", null).create().show();
    }

    @JavascriptInterface
    public void showToast() {

        Toast.makeText(mContext, "hello", Toast.LENGTH_LONG).show();
    }

}

注:AndroidJs是连接Android与Html的桥梁标识,也是一个进行数据交互的类;

注:这里面的方法必须是共有的,类名与标识保持一致;

@希望能帮助到大家

上一篇下一篇

猜你喜欢

热点阅读