与js交互 webview显示不全: 使用原生的webview,在低版本的手机上会有网页显示不全的情况,因此想要适配低版本,提高性能,可使用第三方的。例如腾讯TBS,就是不错的一个选择。网址
webview显示不全: 使用原生的webview,在低版本的手机上会有网页显示不全的情况,因此想要适配低版本,提高性能,可使用第三方的。例如腾讯TBS,就是不错的一个选择。网址:https://x5.tencent.com/tbs/guide/sdkInit.html;按照api接入就可以了。 webview与js的交互: 跟前端的开发约定好方法例如 webView.addJavascriptInterface(new JsOperation(context), "getAppInfo"); getAppInfo要与他们保持一致,JsOperation是咱们自己定义的一个类,如下: public class JsOperation { Activity mActivity; public JsOperation(Activity activity) { mActivity = activity; } @JavascriptInterface//这个注解必须加,只有加入这个注解的方法,才能被前段调用 public String getApp() {//这个方法也必须和前段约定好,保持一致,这个方法是把本地String传给了前端 JSONObject map = null; try { map = new JSONObject(); map.put("key", "android"); } catch (JSONException e) { e.printStackTrace(); } return map.toString(); } } webview的HTTP_REFERER属性配置: //拦截url的方法添加如下代码即可 Map extraHeaders = new HashMap(); extraHeaders.put("Referer", "http....");//http....为要接入url的域名 view.loadUrl(url, extraHeaders); webview中打开高德地图,微信等app方式: //拦截url的方法添加如下代码 if (url.startsWith("weixin://wap/pay?")||url.startsWith("androidamap://route")) { Intent intent = new Intent(); intent.setAction(Intent.ACTION_VIEW); intent.setData(Uri.parse(url)); startActivity(intent); return false; }