Android初級第十講之WebView的故事

 

Webview是谷歌提供一種加載網頁的方式,隨着H5的出現,越來越多的活動頁面出現在Webview上,也出現React Native和Weex這樣的H5框架。因此關於它,我們專門闢出來一節來講講。

 

緩存模式(5種)
LOAD_CACHE_ONLY:  不使用網絡,只讀取本地緩存數據
LOAD_DEFAULT:  根據cache-control決定是否從網絡上取數據。
LOAD_CACHE_NORMAL: API level 17中已經廢棄, 從API level 11開始作用同LOAD_DEFAULT模式
LOAD_NO_CACHE: 不使用緩存,只從網絡獲取數據.
LOAD_CACHE_ELSE_NETWORK,只要本地有,無論是否過期,或者no-cache,都使用緩存中的數據。
如:www.taobao.com的cache-control爲no-cache,在模式LOAD_DEFAULT下,無論如何都會從網絡上取數據,如果沒有網絡,就會出現錯誤頁面;在LOAD_CACHE_ELSE_NETWORK模式下,無論是否有網絡,只要本地有緩存,都使用緩存。本地沒有緩存時才從網絡上獲取。
www.360.com.cn的cache-control爲max-age=60,在兩種模式下都使用本地緩存數據。

 

清除頁面緩存的方式:

 

    /**
     * 清除WebView緩存
     * 爲了頁面加載速度,由h5主動清除,自身不主動
     */
    public void clearWebViewCache() {
        //清理Webview緩存數據庫
        try {
            deleteDatabase("webview.db");
            deleteDatabase("webviewCache.db");
        } catch (Exception e) {
            e.printStackTrace();
        }
        //WebView 緩存文件
        File appCacheDir = new File(getFilesDir().getAbsolutePath() + "/webcache");

        File webviewCacheDir = new File(getCacheDir().getAbsolutePath() + "/webviewCache");

        //刪除webview 緩存目錄
        if (webviewCacheDir.exists()) {
            deleteFile(webviewCacheDir.getAbsolutePath());
        }
        //刪除webview 緩存 緩存目錄
        if (appCacheDir.exists()) {
            deleteFile(appCacheDir.getAbsolutePath());
        }
    }
}

 

WebView緩存方式:

 

1、應用緩存

2、Dom緩存

3、數據庫緩存

4、文件緩存

接入騰訊的瀏覽器內核:http://x5.tencent.com/doc?id=1004

一般爲減少系統內存和泄露危險,採用爲webActivity開啓新進程,兩種方式android:process=":remote"代表歸當前進程私有,只有兩者可以互相訪問;android:process="remote"代表公有進程,其他所有進程均可訪問。

如果各位有問題,歡迎提出;後面有想法,再繼續補充。

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章