天天看點

js與android原生互動

package com.liuhao.mysecond;

import androidx.annotation.RequiresApi;
import androidx.appcompat.app.AppCompatActivity;

import android.annotation.SuppressLint;
import android.content.Context;
import android.content.Intent;
import android.content.pm.ActivityInfo;
import android.graphics.Bitmap;
import android.net.Uri;
import android.os.Build;
import android.os.Bundle;

import android.os.Handler;
import android.util.Log;
import android.view.View;
import android.webkit.JavascriptInterface;
import android.webkit.ValueCallback;
import android.webkit.WebResourceRequest;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Toast;

import com.liuhao.mysecond.WebView.WebViewActivity;


public class MainActivity extends AppCompatActivity {


    @Override
    protected void onResume() {
        /**
         * 設定為橫屏
         */
//        if(getRequestedOrientation()!= ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE){
//            setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
//        }
        super.onResume();
    }


    @SuppressLint("JavascriptInterface")
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        final WebView myWebView = findViewById(R.id.WV_Id);
        myWebView.clearCache(true);

        myWebView.getSettings().setJavaScriptEnabled(true);
        myWebView.getSettings().setJavaScriptCanOpenWindowsAutomatically(true);
        myWebView.getSettings().setDomStorageEnabled(true);
        myWebView.getSettings().setAllowFileAccess(true);
        myWebView.addJavascriptInterface(new JavaScriptinterface(this), "android");
        myWebView.loadUrl("http://10.8.106.67:3000/test.html");
        myWebView.setWebViewClient(new MyWebViewClient());


    }


    @RequiresApi(api = Build.VERSION_CODES.KITKAT)
    public void sendMessage(View view) {
        WebView myWebView = findViewById(R.id.WV_Id);
        myWebView.evaluateJavascript("javascript:AndroidcallJS()", new ValueCallback<String>() {
            @Override
            public void onReceiveValue(String value) {
                //此處為 js 傳回的結果
                Log.i("劉浩:", value);
            }
        });
    }
}

class JavaScriptinterface {
    Context context;

    public JavaScriptinterface(Context c) {
        context = c;
    }

    /**
     * 與js互動時用到的方法,在js裡直接調用的
     */
    @JavascriptInterface
    public void click(String ssss) {

        Toast.makeText(context, ssss, Toast.LENGTH_LONG).show();
    }
}

class MyWebViewClient extends WebViewClient {
    @RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
    @Override  //WebView代表是目前的WebView
    public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
        //表示在目前的WebView繼續打開網頁
        view.loadUrl(request.getUrl().toString());
        return true;
    }

    @Override
    public void onPageStarted(WebView view, String url, Bitmap favicon) {
        super.onPageStarted(view, url, favicon);

    }

    @Override
    public void onPageFinished(WebView view, String url) {
        super.onPageFinished(view, url);

    }

}





      

<div style="margin-top:200px"></div> <span id="liu" οnclick="AndroidcallJS()" href="myapp://" target="_blank" rel="external nofollow" >打開微信</span> <div id="show"></div> <button id="btn" οnclick="window.android.click('77777777777')">掉原生</button> <script>

function AndroidcallJS(){ document.getElementById("show").innerHTML="Android調用了JS的AndroidcallJS方法"   return "99999999999999" } //document.getElementById("liu").click() </script>

轉載于:https://www.cnblogs.com/liuhao-web/p/11550381.html

繼續閱讀