WebView

加載外部頁(yè)面

  1. 需要添加INTERNET權(quán)限
<manifest ... >
    <uses-permission android:name="android.permission.INTERNET" />
    ...
</manifest>
  1. 添加WebView布局
<?xml version="1.0" encoding="utf-8"?>
<WebView  xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/webview"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
/>
  1. 使用WebSettings和創(chuàng)建一個(gè)WebViewClient來配置WebView
public class MainActivity extends Activity {
   private WebView myWebView;

   @Override        
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);
      myWebView = (WebView) findViewById(R.id.webview);
      // Configure related browser settings
      myWebView.getSettings().setLoadsImagesAutomatically(true);
      myWebView.getSettings().setJavaScriptEnabled(true);
      myWebView.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY);
      // Configure the client to use when opening URLs
      myWebView.setWebViewClient(new MyBrowser());
      // Load the initial URL
      myWebView.loadUrl("http://www.example.com");
   }
   
   // Manages the behavior when URLs are loaded
   private class MyBrowser extends WebViewClient {
      @SuppressWarnings("deprecation")
      @Override
      public boolean shouldOverrideUrlLoading(WebView view, String url) {
          view.loadUrl(url);
          return true;
      }

      @TargetApi(Build.VERSION_CODES.N)
      @Override
      public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
          view.loadUrl(request.getUrl().toString());
          return true;
      }
   }
}

處理響應(yīng)式布局

默認(rèn)情況下,如果HTML頁(yè)面包括viewport 元數(shù)據(jù),WebView不考慮默認(rèn)比例尺大小。 如果您希望啟用頁(yè)面加載響應(yīng)式布局,則需要明確設(shè)置:

// Enable responsive layout
myWebView.getSettings().setUseWideViewPort(true);
// Zoom out if the content width is greater than the width of the veiwport
myWebView.getSettings().setLoadWithOverviewMode(true);
myWebView.getSettings().setSupportZoom(true);
myWebView.getSettings().setBuiltInZoomControls(true); // allow pinch to zooom
myWebView.getSettings().setDisplayZoomControls(false); // disable the default zoom controls on the page

加載本地頁(yè)面

如果你想存儲(chǔ)一個(gè)本地網(wǎng)頁(yè)的副本加載到WebView,你可以把它放在android的assets文件夾中。例如:

public class MainActivity extends Activity {
   private WebView myWebView;

   @Override        
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);
      myWebView = (WebView) findViewById(R.id.webview);
      myWebView.getSettings().setJavaScriptEnabled(true);
      myWebView.setWebViewClient(new WebViewClient());
      String path = Uri.parse("file:///android_asset/index.html").toString();
      myWebView.loadUrl(path);
   }

}

在WebView和網(wǎng)絡(luò)客戶端之間共享Cookie

WebViews目前使用自己的Cookie管理器,這意味著您在這些Web視圖之外創(chuàng)建的任何網(wǎng)絡(luò)請(qǐng)求通常單獨(dú)存儲(chǔ)。 當(dāng)嘗試保留相同的Cookie(即用于身份驗(yàn)證或跨站點(diǎn)腳本偽造(CSRF)頭)時(shí),這可能會(huì)導(dǎo)致問題。詳細(xì)請(qǐng)看Stack Overflow articlegist

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容