webview使用起来非常方便,但是由于过大的js或css使加载时间太长,体验不好,拦截js本地注入就是一个很好的解决办法。
wv_webview.getSettings().setJavaScriptEnabled(true); wv_webview.setWebViewClient(new WebViewClient(){ @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { // TODO Auto-generated method stub view.loadUrl(url); return true; } @Override public WebResourceResponse shouldInterceptRequest(WebView view, String url) { Log.e("url","url="+url);// if(url.contains("new_file.js")){//加载指定.js时 引导服务端加载本地Assets/www文件夹下的cordova.js try { return new WebResourceResponse("application/x-javascript","utf-8",getBaseContext().getAssets().open("js/new_file.js")); } catch (IOException e) { e.printStackTrace(); } } else if (url.contains("style.css")){ try { return new WebResourceResponse("text/css","utf-8",getBaseContext().getAssets().open("css/style.css")); } catch (IOException e) { e.printStackTrace(); } } return super.shouldInterceptRequest(view, url); } }); wv_webview.loadUrl("远端url地址");shouldInterceptRequest方法起到了拦截作用 url是你的src的路径,你有多少个js或者css路径 这里就会打印多少次,当判断条件成立就执行注入方法mimeType需要注意对应相应的类型。