Android webview和javascript交互

Android中很多直接显示网页的需求,但是很错不单单只是显示网页就可以了,还需要与网页进行交互,就是所谓的Java与javascript交互。
如何实现:
实现Java和js交互十分便捷。通常只需要以下几步。
WebView开启JavaScript脚本执行
WebView设置供JavaScript调用的交互接口。
客户端和网页端编写调用对方的代码。

先贴出代码:

public class MainActivity extends Activity {

    private WebView webView;
    private String url_path = "http://m.dapu.com/mgallery-promotion-298.html";

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

        initView();

        // 覆盖WebView默认使用第三方或系统默认浏览器打开网页的行为,使网页用WebView打开
        webView.setWebViewClient(new WebViewClient() {

            @Override
            // 在点击请求的是链接是才会调用,重写此方法返回true表明点击网页里面的链接还是在当前的webview里跳转,不跳到浏览器那边。这个函数我们可以做很多操作,比如我们读取到某些特殊的URL,于是就可以不打开地址,取消这个操作,进行预先定义的其他操作,这对一个程序是非常必要的。
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                // 判断url链接中是否含有某个字段,如果有就执行指定的跳转(不执行跳转url链接),如果没有就加载url链接
                if (url.contains("/mproduct-")) {
                    Intent i = new Intent(MainActivity.this, MainActivity.class);
                    startActivity(i);
                    return true;
                } else {
                    return false;
                }
            }

            public void onReceivedSslError(WebView view,
                    SslErrorHandler handler, SslError error) {
                // handler.cancel(); 默认的处理方式,WebView变成空白页
                // //接受证书
                handler.proceed();
                // handleMessage(Message msg); 其他处理
            }

            @Override
            // 此回调是拦截点击要跳转的url链接,并对请求的url链接做修改(添加删除字段)
            public WebResourceResponse shouldInterceptRequest(WebView view,
                    String url) {
                return null;
            }

            @Override
            //加载完页面之后的处理
            public void onPageFinished(WebView view, String url) {
                //网页加载完之后,java调用js方法
                 webView.loadUrl("javascript:shareToFriends()");
                super.onPageFinished(view, url);
            }
        });

        webView.addJavascriptInterface(new JsToJava(), "androidShare");

        webView.setWebChromeClient(new WebChromeClient(){
            //处理javaScrip的Alter事件,这里也可以用android组件替换
            @Override
            public boolean onJsAlert(WebView view, String url, String message,
                    JsResult result) {
                return super.onJsAlert(view, url, message, result);
            }

            //加载进度条
            @Override
            public void onProgressChanged(WebView view, int newProgress) {
                super.onProgressChanged(view, newProgress);
            }

        });

        // WebView加载web资源
        webView.loadUrl(url_path);

    }

    private class JsToJava{
        //这里需要加@JavascriptInterface,4.2之后提供给javascript调用的函数必须带有@JavascriptInterface
        @JavascriptInterface
        public void jsMethod(String paramFromJS){
            System.out.println("js返回结果:" + paramFromJS);//处理返回的结果
        }
    }

    @SuppressLint("SetJavaScriptEnabled")
    private void initView() {
        webView = (WebView) findViewById(R.id.webView);
        WebSettings settings = webView.getSettings();
        settings.setJavaScriptEnabled(true);
        settings.setBuiltInZoomControls(true);// 设置支持缩放
        settings.setSupportZoom(false);// 不支持缩放
        settings.setUseWideViewPort(false);// 将图片调整到适合webview大小
        settings.setLoadWithOverviewMode(true);// 缩放至屏幕的大小
        settings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);//支持缓存

    }

    // 覆盖Activity类的onKeyDown(int keyCoder,KeyEvent event)方法
    public boolean onKeyDown(int keyCode, KeyEvent event) {
        if (keyCode == KeyEvent.KEYCODE_BACK && webView.canGoBack()) {
            webView.goBack();// 返回前一个页面
            // finish();
            return true;
        }
        return super.onKeyDown(keyCode, event);
    }

}

网页代码:

<script  type="text/javascript">
function shareToFriends(){
    var result = "title:'大朴优选:发现光芒之物',desc:'大朴优选:发现光芒之物',link:'http://m.dapu.com/mgallery-promotion- 298.html',imgUrl:'http://activity.dapuimg.com/dapu_20160825000_r1_c1.jpg'";
    window.androidShare.jsMethod(result);
}
</script>

Java调用JS,获取不到返回值

webView调用js的基本格式为webView.loadUrl(“javascript:methodName(parameterValues)”)

获取javascript返回值,首先要对webview绑定javascriptInterface,js脚本通过这个接口来调用java代码。

webView.addJavascriptInterface(new JsToJava(), "androidShare");

JsToJava实际就是一个普通的java类,里面是我们本地实现的java代码, 将object 传递给webview,并指定别名,这样js脚本就可以通过我们给的这个别名来调用我们的方法,在上面的代码中,androidShare是这个对象在js中的别名

private class JsToJava{
        //这里需要加@JavascriptInterface,4.2之后提供给javascript调用的函数必须带有@JavascriptInterface
        @JavascriptInterface
        public void jsMethod(String paramFromJS){
            System.out.println("js返回结果:" + paramFromJS);//处理返回的结果
        }
    }

当网页加载完之后,在加载完回调方法中调用js方法

@Override
            //加载完页面之后的处理
            public void onPageFinished(WebView view, String url) {
                //网页加载完之后,java调用js方法
                 webView.loadUrl("javascript:shareToFriends()");
                super.onPageFinished(view, url);
            }

然后执行js方法,js方法中在调用java注册的方法来回来数据给java

function shareToFriends(){
    var result = "title:'大朴优选:发现光芒之物',desc:'大朴优选:发现光芒之物',link:'http://m.dapu.com/mgallery-promotion- 298.html',imgUrl:'http://activity.dapuimg.com/dapu_20160825000_r1_c1.jpg'";
    window.androidShare.jsMethod(result);
}

window.androidShare.jsMethod(result);这行代码就是javascript调用java代码返回数据给java

补充:
对于Android调用JS代码的方法有2种:
Android 4.4以下使用方法1,Android 4.4以上方法2
1. 通过WebView的loadUrl()
2. 通过WebView的evaluateJavascript()

通过WebView的loadUrl()

// 调用javascript的callJS()方法
 mWebView.loadUrl("javascript:callJS()");

关于调用js方法传值的参数写法
webView.loadUrl("javascript:callJS('" + name + "','" + password + "')");

通过WebView的evaluateJavascript()

// 只需要将第一种方法的loadUrl()换成下面该方法即可
    mWebView.evaluateJavascript("javascript:callJS()", new ValueCallback<String>() {
        @Override
        public void onReceiveValue(String value) {
            //此处为 js 返回的结果
        }
    });
}

源码下载

  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Android WebView 是一个能够在 Android 应用程序中嵌入网页的组件,它可以开发出能够与 Web 页面进行交互的应用。其中与 Web 页面进行交互的一种方法是与 JavaScript 进行交互。下面简要解释一下 Android WebView 与 JS 交互的方式。 1. 加载本地 HTML 文件 在 Android WebView 中加载本地 HTML 文件时,需要使用 loadUrl() 方法加载。HTML 文件中的 JavaScript 可以通过 WebView 提供的 addJavascriptInterface() 方法注册为 Java 中的一个对象,然后在 Java 中调用该对象的方法,即可实现 JS 与 Java 的交互。 2. 加载远程 Web 页面 在 Android WebView 中加载远程 Web 页面时,需要添加 WebViewClient 和 WebChromeClient,分别是用来管理 WebView 的网络请求和处理页面上的 JavaScript 弹窗等请求。 在远程 Web 页面上,JS 代码可以通过 WebView 提供的 addJavascriptInterface() 方法注册为 Java 中的一个对象,然后在 Java 中调用该对象的方法,即可实现 JS 与 Java 的交互。 同时,在 Android 中处理 JS 的事件需要通过 JavaScriptInterface 向 WebView 注册一个映射对象,来实现 JS、Java 相互调用的机制,静态 HTML 文件是通过 WebView 中的 evaluateJavascript() 方法来调用 JS,来实现双向通信和数据交互。 总结来说,Android WebView 与 JS 交互的方式主要是通过 WebView 提供的 addJavascriptInterface() 方法注册为 Java 中的一个对象,然后在 Java 中调用该对象的方法,来实现 JS 和 Java 的交互。同时,JS 也可以通过 WebView 的 evaluateJavascript() 方法来调用 Java 中的方法,实现双向通信和数据交互

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值