加載外部頁(yè)面
- 需要添加INTERNET權(quán)限
<manifest ... >
<uses-permission android:name="android.permission.INTERNET" />
...
</manifest>
- 添加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"
/>
- 使用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 article和gist