- 重点1:loadUrl及loadDataWithBaseURL的使用
这部分内容已经在 UI组件——WebView部分api释义 讲过了,还不懂得可以去看一下
- 重点2:h5页面在Android WebView中的适配问题
笔者踩过的坑是h5页面未对移动端做任何适配,而且在h5页面指定了,导致Android端适配很差,我们Android端在这里自己搞各种适配的工作,结果还是不理想,其实这个问题理想解决方法是:h5页面要尽量使用百分比布局,比如指定width:100%,那么就能解决多数问题,但是还有一类问题无法解决,h5页面中的有些文本在移动端显示的特别小,如果想要正常显示,那么在h5的中添加 name=”viewport” content=”width=device-width”来解决;具体为
- 重点3:对加载网页时出现的失败网页的处理
通常情况下,WebView加载网页如果出现错误,那么错误提示便是网页本身的错误提示,这对用户来说很不友好,因此,为了给客户良好的体验感,我们会把原生的错误提示页面替换为一个比较友好的提示页面,具体是什么页面可以找设计。要替换原生的错误页面,我们就要知道当页面发生错误时会回调什么方法,然后我们在那里做拦截处理,便可以成功替换页面了。当加载错误时会回调onReceivedError(WebView view, WebResourceRequest request, WebResourceError error)和onReceivedHttpError( WebView view, WebResourceRequest request, WebResourceResponse errorResponse),因此我们在这里做替换就可以了。注意,第一个方法要求api 23,要做一些适配工作,比如,我们可以判断版本>23时用第一个方法,其他情况下用这个方法:onReceivedError(WebView view, int errorCode,String description, String failingUrl)。
- 重点4:与js交互
这是WebView的重中之重,分两个方向讲1:Android调用js,2:js调用Android
- 1:Android调用js
android 调用js又分为两种情况,一种是无返回值的调用,一种是有返回值的调用。无论哪种情况都需要添加webSettings.setJavaScriptEnabled(true);否则不会生效
- a:无返回值的交互
Android调用js无需返回值时直接使用:webview.loadUrl(str);str是需要执行的js语句,UI组件——WebView部分api释义 这里已经讲过了。 - b:有返回值的调用
Android调用js有返回值的方法是在Android4.4(api 19)以后新增的方法:evaluateJavascript(String script, ValueCallback resultCallback);script是即将执行的js语句,resultCallback是执行
- a:无返回值的交互
- 1:Android调用js