WebView与js交互

main下新建一个文件assets---www---index.html:            布局加一个webview  然后添加一个网络权限

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>hybird</title>
    <script>
        function onJsToNative(){
            var value=document.getElementById("inputValue").value;
            alert(value);
             window.location.href="login://usermanager/userlogin?userName="+value;
        }

        function onJsToNative2(){
           myApp.showToast("from html show on native !");
        }

        function onNativeToJs(fromNativeValue){
            alert(fromNativeValue);
        }

    </script>
</head>
<body>

<img src="https://www.baidu.com/img/bd_logo1.png">
<img src="http://img04.sogoucdn.com/app/a/100520024/4edf482718b95060bbdd6b886248296d">

<input id="inputValue">
<button οnclick="onJsToNative()">jsToNative</button>
<button οnclick="onJsToNative2()">jsToNative2</button>

</body>
</html>
 
 
MianActivity:
public class MainActivity extends AppCompatActivity {
    private com.tencent.smtt.sdk.WebView load;

//    private WebView load;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        initView();
        initData();
    }

    private void initData() {
        load.loadUrl("file:///android_asset/www/index.html");
        WebSettings websetting = load.getSettings();
        websetting.setJavaScriptEnabled(true);
        String ua = websetting.getUserAgentString();
        websetting.setUserAgentString(ua+" bwie");
        load.setWebChromeClient(new WebChromeClient() {

        });
        load.setWebViewClient(new WebViewClient() {
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {

                if (url.startsWith("login://") && url.contains("userlogin")) {
                    Uri uri = Uri.parse(url);
                    String userName = uri.getQueryParameter("userName");
                    showToast(userName);
                    nativeToHTML();
                    return true;
                }

                return super.shouldOverrideUrlLoading(view, url);
            }
        });
        load.addJavascriptInterface(new MyJavaScriptInter(),"myApp");
    }

    private void initView() {
        load = (com.tencent.smtt.sdk.WebView) findViewById(R.id.webview_mian_loaddatel);
    }

    public void showToast(String str) {
        Toast.makeText(MainActivity.this, str, Toast.LENGTH_LONG).show();

    }

    class MyJavaScriptInter {
        @JavascriptInterface
        public void showToast(String str) {
            MainActivity.this.showToast(str);
        }
    }

    public void nativeToHTML() {
        if (Build.VERSION.SDK_INT < 19) {
            load.loadUrl("javascript:onNativeToJs('from native')");
        } else {
            load.evaluateJavascript("javascript:onNativeToJs('from native')", null);
        }

//        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
//            load.getSettings().setMixedContentMode(WebSettings.MIXED_CONTENT_ALWAYS_ALLOW);
//        }
    }
}
 

在 Android 中,WebView 是一个内置的浏览器控件,可以加载网页并在应用程序中显示。WebView 与 JavaScript 的交互是常见的需求,主要有以下几种方式: 1. 通过 WebView 中的 loadUrl() 方法调用 JavaScript 函数。 可以使用 WebView 的 loadUrl() 方法加载一个包含 JavaScript 代码的 URL,实现与 JavaScript 的交互。例如,在 JavaScript 中定义一个函数: ```javascript function showToast(message) { alert(message); } ``` 然后在 Android 中使用 loadUrl() 方法调用这个函数: ```java webView.loadUrl("javascript:showToast('Hello World!')"); ``` 2. 在 WebView 中启用 JavaScript,并使用 addJavascriptInterface() 方法将 Java 对象注入到 JavaScript 中。 可以在 WebView 中启用 JavaScript 支持,并使用 addJavascriptInterface() 方法将 Java 对象注入到 JavaScript 中。这样,JavaScript 就可以调用 Java 对象的方法。例如,在 Java 中定义一个类: ```java public class MyJavaScriptInterface { private Context context; public MyJavaScriptInterface(Context context) { this.context = context; } @JavascriptInterface public void showToast(String message) { Toast.makeText(context, message, Toast.LENGTH_SHORT).show(); } } ``` 然后在 WebView 中启用 JavaScript 支持,并将 MyJavaScriptInterface 对象注入到 JavaScript 中: ```java webView.getSettings().setJavaScriptEnabled(true); webView.addJavascriptInterface(new MyJavaScriptInterface(this), "Android"); ``` 在 JavaScript 中就可以调用 MyJavaScriptInterface 对象的 showToast() 方法: ```javascript Android.showToast("Hello World!"); ``` 3. 使用 evaluateJavascript() 方法执行 JavaScript 代码并获取返回值。 可以使用 WebView 的 evaluateJavascript() 方法执行 JavaScript 代码,并通过回调函数获取返回值。例如,在 JavaScript 中定义一个函数: ```javascript function add(a, b) { return a + b; } ``` 然后在 Android 中使用 evaluateJavascript() 方法执行这个函数,并获取返回值: ```java webView.evaluateJavascript("add(1, 2)", new ValueCallback<String>() { @Override public void onReceiveValue(String value) { // value = "3" } }); ``` 以上就是 WebView 与 JavaScript 的交互方式,开发者可以根据需求选择适合自己的方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值