Android WebView 加载富文本内容

WebView加载数据的方式有两种:html

1. webView.loadUrl(data);//加载url
2. webView.loadDataWithBaseURL(null,data, "text/html" , "utf-8", null);//加载html数据

 能够使用来加载富文本内容:web

webView.loadDataWithBaseURL(null,data, "text/html" , "utf-8", null);

为了使WebView在手机上能更好的展现富文本内容,推荐以下的WebSetting:浏览器

WebSettings settings = webView.getSettings(); // 设置WebView支持JavaScript
        settings.setJavaScriptEnabled(true); //支持自动适配
        settings.setUseWideViewPort(true); settings.setLoadWithOverviewMode(true); settings.setSupportZoom(true);  //支持放大缩小
        settings.setBuiltInZoomControls(true); //显示缩放按钮
        settings.setBlockNetworkImage(true);// 把图片加载放在最后来加载渲染
        settings.setAllowFileAccess(true); // 容许访问文件
        settings.setSaveFormData(true); settings.setGeolocationEnabled(true); settings.setDomStorageEnabled(true); settings.setJavaScriptCanOpenWindowsAutomatically(true);/// 支持经过JS打开新窗口
 settings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.NARROW_COLUMNS); settings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN); //设置不让其跳转浏览器
        webView.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { return false; } }); // 添加客户端支持
        webView.setWebChromeClient(new WebChromeClient()); // mWebView.loadUrl(TEXTURL); //不加这个图片显示不出来
        if (Build.VERSION.SDK_INT > Build.VERSION_CODES.LOLLIPOP) { webView.getSettings().setMixedContentMode(WebSettings.MIXED_CONTENT_ALWAYS_ALLOW); } webView.getSettings().setBlockNetworkImage(false); //容许cookie 否则有的网站没法登录
        CookieManager mCookieManager = CookieManager.getInstance(); mCookieManager.setAcceptCookie(true); mCookieManager.setAcceptThirdPartyCookies(webView, true); webView.loadUrl(URL);

 

补充:

当咱们使用WebView加载富文本网页文件时,可能存在某些机型上展现内容乱码的问题。cookie

解决方案:ide

1.首先设置html头文件为 utf-8,示例代码以下:网站

<head>
    <title>这是标题</title>
    <meta name="content-type" content="text/html; charset=utf-8">
    <meta http-equlv="Content-Type" content="text/html;charset=utf-8">
</head>

2. 其次保证webView设置的编码与html设置编码一致:ui

webview.getSettings().setDefaultTextEncodingName("utf-8");