久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

HTML5應(yīng)用程序緩存Application Cache詳解

HTML5引入了應(yīng)用程序緩存技術(shù),意味著web應(yīng)用可進行緩存,并在沒有網(wǎng)絡(luò)的情況下使用,通過創(chuàng)建cache manifest文件,可以輕松的創(chuàng)建離線應(yīng)用。,HTML5中國,中國最大的HTML5中文門戶。
什么是Application Cache

HTML5引入了應(yīng)用程序緩存技術(shù),意味著web應(yīng)用可進行緩存,并在沒有網(wǎng)絡(luò)的情況下使用,通過創(chuàng)建cache manifest文件,可以輕松的創(chuàng)建離線應(yīng)用。

Application Cache帶來的三個優(yōu)勢是:

① 離線瀏覽

② 提升頁面載入速度

③ 降低服務(wù)器壓力

而且主要瀏覽器皆以支持Application Cache,就算不支持也不會對程序造成什么影響

離線存儲技術(shù)

HTML5提出了兩大離線存儲技術(shù):localstorage與Application Cache,兩者各有應(yīng)用場景;傳統(tǒng)還有離線存儲技術(shù)為Cookie。

經(jīng)過實踐我們?nèi)蝿?wù)localstorage應(yīng)該存儲一些非關(guān)鍵性ajax數(shù)據(jù),做錦上添花的事情;

Application Cache用于存儲靜態(tài)資源,仍然是干錦上添花的事情;

而cookie只能保存一小段文本(4096字節(jié));所以不能存儲大數(shù)據(jù),這是cookie與上述緩存技術(shù)的差異之一,而因為HTTP是無狀態(tài)的,服務(wù)器為了區(qū)分請求是否來源于同一個服務(wù)器,需要一個標(biāo)識字符串,而這個任務(wù)就是cookie完成的,這一段文本每次都會在服務(wù)器與瀏覽器之間傳遞,以驗證用戶的權(quán)限。

所以Application Cache的應(yīng)用場景不一樣,所以使用也不一致。

Application Cache簡介

Application Cache的使用要做兩方面的工作:

① 服務(wù)器端需要維護一個manifest清單

② 瀏覽器上只需要一個簡單的設(shè)置即可

  1. <html  manifest="demo.appcache">
復(fù)制代碼

以例子做說明:

  1. CACHE MANIFEST

  2. CACHE:
  3. # 需要緩存的列表
  4. style1.css
  5. 1.jpg
  6. 01.js

  7. http://localhost/applicationcache/02.js


  8. http://localhost/applicationcache/zepto.js

  9. NETWORK:
  10. # 不需要緩存的
  11. 4.jpg

  12. FALLBACK:
  13. # 訪問緩存失敗后,備用訪問的資源,第一個是訪問源,第二個是替換文件*.html /offline.html
  14. 2.jpg/3.jpg
復(fù)制代碼

首先我這里報了一個錯:

  1. Application Cache Error event: Manifest fetch failed (404)
復(fù)制代碼

這個錯誤的原因是:manifest 文件需要配置正確的 MIME-type,即 “text/cache-manifest”。必須在 web 服務(wù)器上進行配置,不同的服務(wù)器不一樣



  1. \APPLICATIONCACHE
  2.     01.js
  3.     02.js
  4.     1.jpg
  5.     2.jpg
  6.     3.jpg
  7.     4.jpg
  8.     demo.appcache
  9.     index.html
  10.     style1.css
  11.     style2.css
  12.     web.config
  13.     zepto.js
復(fù)制代碼

這樣一來便可以離線應(yīng)用了,這個時候就算斷網(wǎng)了,那些文件依舊能訪問


這里有一點值得注意,比如這里不帶/index.html他會將“applicationcache/”緩存,其實這個就是index.html

manifest 文件可分為三個部分:
CACHE MANIFEST - 在此標(biāo)題下列出的文件將在首次下載后進行緩存
NETWORK - 在此標(biāo)題下列出的文件需要與服務(wù)器的連接,且不會被緩存
FALLBACK - 在此標(biāo)題下列出的文件規(guī)定當(dāng)頁面無法訪問時的回退頁面(比如 404 頁面)


如圖所示,HTML5定義了幾個事件點,但是我們一般不會主動使用js去操作什么,大多數(shù)情況下,我們完全依賴瀏覽器的處理即可。

尺寸限制

Application Cache的尺寸限制統(tǒng)一在5M,我這里做一個測試:


如所示,兩個css文件依舊超過了5M這個時候

  1. Document was loaded from Application Cache with manifest http://localhost/applicationcache/demo.appcache
  2. index.html:1 Application Cache Checking event
  3. index.html:6 GET http://localhost/applicationcache/style2.css net::ERR_FAILED
  4. index.html:1 Application Cache NoUpdate event
  5. index.html:11 GET http://localhost/applicationcache/2.jpg net::ERR_FAILED
  6. index.html:12 GET http://localhost/applicationcache/3.jpg net::ERR_FAILED
復(fù)制代碼

如所示,style2已經(jīng)不能緩存了,這個會造成什么問題呢?

比如我A頻道維護了自己的Application Cache,B頻道也維護了自己的,這個時候A頻道如果使用達到了一個峰值,會導(dǎo)致B頻道所有的緩存失效,所以:

建議Application Cache,存儲公共資源,不要存儲業(yè)務(wù)資源

一些問題

由更新機制來說,首次更新manifest時,因為頁面加載已經(jīng)開始甚至已經(jīng)完成,緩存更新尚未完成,瀏覽器仍然會使用過期的資源;瀏覽器是當(dāng)Application Cache有更新時,該次不會使用新資源,第二次才會使用。這個時候update事件中執(zhí)行window.reload事件。

  1. window.applicationCache.addEventListener("updateready", function(){
  2.     window.location.reload()
  3. });
復(fù)制代碼

由上例可以知道,緩存的不只是顯示定義的文件,比如上例中的applicationcache/時便會默認保存index.html為映射的數(shù)據(jù),并且包含demo.appcache文件,很多時候會遇到一次文件更新線上老是不更新,這個時候隨便在manifest配置文件中做一點修改即可更新。

比如我們將這里代碼做一個改變:

  1. <html  manifest="demo.appcache">
  2. =>
  3. <html  manifest="demo1.appcache">
復(fù)制代碼

這個時候如果不做demo.appcache的更新的話,緩存將不會更新,原因是index.html被緩存了,檢測的仍然是原manifest清單

各個頁面統(tǒng)一管理自己的manifest清單,意思是a頁面配置了common.js,b頁面也配置了common.js,意思是a頁面更新后,b頁面的manifest不更改的話,b頁面依舊讀取的是老版本的文件,這個有一定道理卻也有一定浪費,需要公共頁面做處理。

總結(jié)

從可用性與易用性來說,Application Cache是值得使用的,但是最好是做靜態(tài)資源的緩存,真正要實現(xiàn)離線應(yīng)用還得花更多的功夫呢!

參考:http://www.w3school.com.cn/html5/html_5_app_cache.asp

via:http://www.codeceo.com/article/html5-application-cache.html

【網(wǎng)站聲明】本站除付費源碼經(jīng)過測試外,其他素材未做測試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請勿用于商業(yè)用途。如損害你的權(quán)益請聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

由于實際運行環(huán)境是在瀏覽器中,因此性能還取決于JavaScript解釋器的效率,指定的FPS幀速在低性能解釋器中可能不會達到,所以這部分不是開發(fā)者能夠決定的,開發(fā)者能作的是盡可能通
本文將使用HTML5提供的VideoAPI做一個自定義的視頻播放器,需要用到HTML5提供的video標(biāo)簽、以及HTML5提供的對JavascriptAPI的擴展。,HTML5中國,中國最大的HTML5中文門戶。
隨著 Hybrid 應(yīng)用的豐富,HTML5 工程師們已經(jīng)不滿足于把桌面端體驗簡單移植到移動端,他們覬覦移動原生應(yīng)用人性化的操作體驗,特別是原生應(yīng)用與生俱來的豐富的手勢系統(tǒng)。HTML5 沒有提
你想要在自己網(wǎng)站上分享一個產(chǎn)品,或者是一個作品集,又或者僅僅只是一個靈感。在你發(fā)布到網(wǎng)上之前,你想讓它看起來有吸引力,專業(yè),或者至少得看起來像那么回事。那么你接下
H5廣告,包括H5廣告的設(shè)計流程,究竟有什么講究,和階段。為了能幫助更多的人了解H5廣告,我專門做了一個講義。同時,也讓我意外的收到了非常好反饋和認!這是對我的極大鼓勵!我的
本文主要內(nèi)容有:框架與組件、構(gòu)建生態(tài)、開發(fā)技巧與調(diào)試、html、css與重構(gòu)、native/hybrid/桌面開發(fā)、前端/H5優(yōu)化、全棧/全端開發(fā)、研究實驗、數(shù)據(jù)分析與監(jiān)控、其它軟技能、前端技術(shù)網(wǎng)
主站蜘蛛池模板: 日韩亚洲视频 | 亚洲精品亚洲人成人网 | 羞羞视频网站在线观看 | 在线免费观看a级片 | 黄色片大全在线观看 | 日韩在线观看中文字幕 | 亚洲精彩视频 | 免费观看国产视频在线 | 色姑娘av| 欧美另类视频 | 人人射人人 | 五月天综合网 | av大片在线| 亚洲区中文字幕 | 91福利网址 | 欧美一级毛片免费观看 | 一本一道久久a久久精品综合蜜臀 | 精彩视频一区二区三区 | 日本国产高清 | 四虎最新视频 | 欧美 日韩精品 | 蜜臀av日日欢夜夜爽一区 | 精品日韩在线 | 国产婷婷| 久久久激情视频 | 中文字幕影院 | 精久久久 | www亚洲免费国内精品 | 99热这里有精品 | 日韩精品在线看 | 91久久精品 | 国产综合av | 一区二区免费 | 懂色av色香蕉一区二区蜜桃 | 婷婷久久五月天 | 2018中文字幕第一页 | 中文字幕高清免费日韩视频在线 | 一区二区高清 | 久久人人网 | 久久免费福利 | 99精品久久久久久久 |