Android 4.4 中 WebView 使用注意事项

自Android 4.4起,Android中的WebView开始基于Chromium( 这大概是因为Android部门负责人从Andy Rubin变成了Chrome部门的主管Sundar Pichai了吧)。 这个改变,使得WebView的性能大幅度提升,并且对HTML5, CSS3, and JavaScript有了更好的支持。 那么,作为一个客户端开发者,我们写代码的时候需要注意哪些呢?
1. 多线程
如果你在子线程中调用WebView的相关方法,而不在UI线程,则可能会出现无法预料的错误。 所以,当你的程序中需要用到多线程时候,也请使用 runOnUiThread()方法来保证你关于WebView的操作是在UI线程中进行的:

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. runOnUiThread(newRunnable(){  
  2. @Override  
  3. publicvoid run(){  
  4.    // Code for WebView goes here  
  5.    }  
  6. });  
2. 线程阻塞
永远不要阻塞UI线程,这是开发Android程序的一个真理。虽然是真理,我们却往往不自觉的犯一些错误违背它,一个开发中常犯的错误就是:在UI线程中去等待JavaScript 的回调。 例如:

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. // This code is BAD and will block the UI thread  
  2. webView.loadUrl("javascript:fn()"); while(result ==null){   
  3. Thread.sleep(100); }  
千万不要这样做,Android 4.4中,提供了新的Api来做这件事情。  evaluateJavascript() 就是专门来异步执行JavaScript代码的。
3. evaluateJavascript() 方法
专门用于异步调用JavaScript方法,并且能够得到一个回调结果。 示例:

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. mWebView.evaluateJavascript(script, new ValueCallback<String>() {  
  2.  @Override  
  3.  public void onReceiveValue(String value) {  
  4.       //TODO  
  5.  }  
  6. });  
4. 处理 WebView 中 url 跳转
新版WebView对于自定义scheme的url跳转,新增了更为严格的限制条件。  当你实现了 shouldOverrideUrlLoading() 或 shouldInterceptRequest() 回调,WebView 也只会在跳转url是合法Url时才会跳转。 例如,如果你使用这样一个url :

<a href="showProfile" >Show Profile</a>

shouldOverrideUrlLoading() 将不会被调用。正确的使用方式是:<a href="example-app:showProfile" >Show Profile</a>

对应的检测Url跳转的方式:

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. // The URL scheme should be non-hierarchical (no trailing slashes)  
  2.  private static final String APP_SCHEME ="example-app:";  
  3.    
  4.  @Override public boolean shouldOverrideUrlLoading(WebView view,String url){  
  5.      if(url.startsWith(APP_SCHEME)){  
  6.          urlData = URLDecoder.decode(url.substring(APP_SCHEME.length()),"UTF-8");  
  7.          respondToData(urlData);  
  8.          returntrue;  
  9.      }  
  10.      return false; }  
当然,也可以这样使用:
webView.loadDataWithBaseURL("example-app://example.co.uk/", HTML_DATA,
null,"UTF-8",null);
5. UserAgent 变化
如果你的App对应的服务端程序,会根据客户端传来的UserAgent来做不同的事情,那么你需要注意的是,新版本的WebView中,UserAgent有了些微妙的改变:

Mozilla/5.0 (Linux; Android 4.4; Nexus 4 Build/KRT16H)
AppleWebKit/537.36(KHTML, like Gecko) Version/4.0 Chrome/30.0.0.0

Mobile Safari/537.36

使用 getDefaultUserAgent()方法可以获取默认的UserAgent,也可以通过:

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. mWebView.getSettings().setUserAgentString(ua);  
  2. mWebView.getSettings().getUserAgentString();  

来设置和获取自定义的UserAgent。

6. Remote Debugging

新版的WebView还提供了一个很厉害的功能:使用Chrome来调试你运行在WebView中的程序。具体可以看: remote-debugging

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值