学向勤中得,萤窗万卷书。这篇文章主要讲述安卓原生与hml交互(WebView基础)相关的知识,希望能为你提供帮助。
- WebView加载页面
加载网络地址
webView.loadUrl("www.xxx.com/index.html");
加载本地资源
webView.loadUrl("file:///android_asset/example.html");
- 添加请求头信息,在这里可以加入认证信息等等
Map< String,String> map=new HashMap< String,String> (); map.put("taken","1234"); webView.loadUrl("http://192.168.99.101:8080/xiaoyanAPI/test1",map);
- 设置页面内链接跳转,拦截了跳转事件,在相应函数中做对应的处理。
webView.setWebViewClient(new WebViewClient() { public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); return true; } });
- 设置允许js方法执行
WebSettings webSettings=webView.getSettings(); webSettings.setjavascriptEnabled(true);
- 返回键返回上个页面(默认webView将页面存放到缓存栈中)
@Override public boolean onKeyDown(int keyCode, KeyEvent event) { if (keyCode == KeyEvent.KEYCODE_BACK) { if (webView.canGoBack()) { webView.goBack(); //返回上一浏览页面 return true; } else { finish(); //关闭Activity } } return super.onKeyDown(keyCode, event); }
- 安卓调用html的js方法
mWebView.evaluatejavascript("sum(1,2)", new ValueCallback< String> () { @Override public void onReceiveValue(String value) { Log.e(TAG, "onReceiveValue value="https://www.songbingjia.com/android/+ value); } });
- js调用安卓原始里的方法。
public class JsInteration { @JavascriptInterface public String back() { return "hello world"; } }
定义完这个方法后再调用mWebView.addJavascriptInterface()方法:
mWebView.addJavascriptInterface(new JsInteration(), "android");
那么在js中怎么来调用呢?
< script type="text/javascript"> function s(){ //调用Java的back()方法 var result =window.android.back(); document.getElementById("p").innerHTML=result; }< /script>
推荐阅读
- 移动端app性能测试——monkey
- Android攻城狮Dialog
- Android 调用优酷SDK上传视频
- android ListView中使用notifyDataSetChanged()不刷新
- Android BlueDroid(BlueDroid蓝牙开启过程enable)
- Android之旅---广播(BroadCast)
- Android攻城狮使用LogCat方式调试程序
- android读取xml文件来实现省份,城市,区的选择
- log4j emailEmailDailyRollingFileAppender