MIS2000Lab.的「HTML5 認證考試, 從零開始」#22 / 23 --- 使用 Indexed Database API & 使用Application Cache加入離線支援

摘要:MIS2000Lab.的「HTML5 認證考試, 從零開始」#22 / 23 ---
使用 Indexed Database API & 使用Application Cache加入離線支援





 

 

上一篇文章:MIS2000Lab.的「HTML5 認證考試,從零開始」#20 / 21 --- Session Storage & Local Storage(永久存放區) 

 

本文內容,將會在2014年底,碁峰出版社推出的HTML5新書裡面

不好意思,因為內容將會出書,所以目前公開的東西都經過大量簡化
日後出書的話,針對每一個方法、屬性都會仔細解說
 

MIS2000Lab.的「HTML5 認證考試,從零開始」#22-- 使用 Indexed Database API 儲存結構化資料

http://ithelp.ithome.com.tw/question/10160292

Indexed Database API或是IndexedDB提供有效的方法來存放、取得與搜尋瀏覽器在設備上 or 存放在本地的結構化資料。

也可以透過window物件的indexedDB屬性來存取indexedDB。
 
 
==== .open()方法與createObjectStore函式 ====
 
您可以透過 .open()函式開啟資料庫(這裡指的是類似資料庫,用來存放資料的東西),
如果資料庫不存在,那麼.open()就會自動建立它。
 
IndexedDB是非同步的(Async.)我們可以使用onsuccess事件獲得.open()以後取得的值,也可以透過onerror事件取得失敗的原因。
 
下面的程式碼範例可以建立一個資料庫的參考並開啟之
 
var db; // Reference to the database to use  
var openRequest = indexedDB.open("contosoDB");  
  
openRequest.onsuccess = function(event) {  
db = event.target.result;  
};  
  
openRequest.onerror = function(event) {  
alert("錯誤訊息: " + event.target.errorCode + "。開啟資料庫時發現錯誤!");  
};  
  
// 註解:設定openRequest變數是一個很安全的設定,確保JavaScript程式區塊都完成之後才會啟動onsuccess或onerror事件。  

 

下面的程式碼範例建立了一個attendee物件來存放參與者的個人資料。
id屬性則是一個主要索引鍵,用來區分每一位參與者。
var attendee = {  
id: "1",  
name: "MIS2000 Lab",  
password: "Pa$$w0rd"  
};  
  
var attendeeStore = db.createObjectStore("attendees",   
{ keyPath: "id" });  

 

==== 各種常用的方法 ====
 
 
使用.add()方法將其他記錄存入物件儲存區(object storage),下面的範例會加入Bill Gates這位人物。
var newAttendee = {  
id: "2",  
name: "Bill Gates",  
password: "Pa$$w0rd"  
};  
  
var addRequest = attendeeStore.add(newAttendee);

 

如果您要修改現存的(既有)紀錄,請使用.put()方法。
 
var updatedAttendee = {  
id: "2",     // 修改既有的資料,例如id=2的個人資料。  
name: "Bill Gates",  
password: "P@ssw0rd" // Change the password  
};  
  
var updateRequest = attendeeStore.put(updatedAttendee); 

 

.delete()方法可以用來刪除記錄,
 
搜尋資料請善用.get()方法
 
微軟提供另一個網址(http://go.microsoft.com/fwlink/?LinkID=267737
進一步介紹IndexedDB的範例,讀者可以前往學習。
 
 
 
==== Indexed Database API的範例(I)====
 
 
這幾個範例是從W3C官方網站取得(http://www.w3.org/TR/IndexedDB/),
 
讀者可以從這幾個範例裡面,看到更詳細的作法。請依照自己學習進度來參考本節範例。
 
 
部分HTML5的新功能(尤其是IndexedDB API)受限於您的Web Server與瀏覽器版本,
 
無法保證在所有讀者的電腦上都能正確運作。
 
 
建議您安裝最新版的Web Server與瀏覽器,最好多安裝幾套不同廠牌瀏覽器來測試。
 
 
範例一:連結一個不存在的資料庫(名為library)並且建立物件與索引。
 
var request = indexedDB.open("library");  
  
request.onupgradeneeded = function() {  
// 資料庫之前不存在,所以必須為它建立物件(object)與索引(index)。  
  var db = request.result;  
  
  var store = db.createObjectStore("books", {keyPath: "isbn"});  
  
  var titleIndex = store.createIndex("by_title", "title", {unique: true});  
  var authorIndex = store.createIndex("by_author", "author");  
  
     // 加入一些數據、資料。例如:書名、作者、ISBN編號。  
     store.put({title: "Quarry Memories", author: "Fred", isbn: 123456});  
     store.put({title: "Water Buffaloes", author: "Fred", isbn: 234567});  
     store.put({title: "Bedrock Nights", author: "Barney", isbn: 345678});  
};  
  
request.onsuccess = function() {  
     db = request.result;  
};  

 

範例二:使用「交易(transaction)」的方式來做,大致跟範例一雷同。
.put()方法是用來修改既有的紀錄。
var tx = db.transaction("books", "readwrite");  
var store = tx.objectStore("books");  
  
store.put({title: "Quarry Memories", author: "Fred", isbn: 123456});  
store.put({title: "Water Buffaloes", author: "Fred", isbn: 234567});  
store.put({title: "Bedrock Nights", author: "Barney", isbn: 345678});  
  
tx.oncomplete = function() {  
// 如果所有要求都成功了,這裡可以撰寫交易成功(transaction commit)的程式碼。  
}; 

 

微軟網站有另外一個 Indexed Database的大範例
 
您也可以參考一下 http://msdn.microsoft.com/en-us/library/ie/jj154908(v=vs.85).aspx
 
 
 
 




 
======================================================================
 
MIS2000Lab.的「HTML5 認證考試,從零開始」#23-- 使用Application Cache加入離線支援
 
 
 
本文內容,將會在2014年底,碁峰出版社推出的HTML5新書裡面
不好意思,因為內容將會出書,所以目前公開的東西都經過大量簡化
日後出書的話,針對每一個方法、屬性都會仔細解說
 
 
Session storage、local storage與IndexedDB API提供程式設計師可以儲存與管理「使用者設備(user’s device)」裡的資料。
 
HTML5(或是傳統網頁)技術都可以把您觀賞的網頁與其他資源(例如圖片、影片)放在您自己(使用者)的設備上(這種動作稱為「快取」,cache),下載的資訊可供重複使用而不需每次都得上網擷取相同的資料。
 
如此一來,資料已經存放在用戶端(Client-side),便可以減少重複存取的動作與網路流量,加速使用者的瀏覽經驗。
 
這些離線的資源(已經存放在使用者的設備上),能讓JavaScript與Application Cache API直接存取,不需要每次使用都要連網。
 
也可以透過JavaScript偵測連網狀態(目前是否連線中?)以便上網擷取最新版本的資源 或是沿用既有(快取)的資源即可。
 
 
==== 設定Applicatiion Cache ====
 
快取清單檔案(cache manifest file)定義了哪些資源必須被瀏覽器放在Application Cache裡面。
 
設定檔區分了這些離線資源應該被放在CACHE、NETWORK或是FALLBACK的區域裡面,
 
讓網頁或程式可以在連線時(On-line)、離線時(Off-line)去存取哪些資源。
 
基本的清單檔案(manifest file)內容如下,副檔名為 .manifest:
 
 
CACHE MANIFEST     
#註解:共有CACHE、NETWORK或是FALLBACK三個區塊  
#      副檔名為 .manifest。  
  
CACHE:  
index.html  
verification.js  
site.css  
graphics/logo.jpg  
  
NETWORK:  
login  
#在此寫上對應的URL網址  
#註解:請用「#」符號加入註解文字  
  
FALLBACK:  
ajax/account/ noCode.html  
#註解:AJAX/account/ 路徑中的所有URL都被替換為noCode.htm網頁。  

 

搭配了manifest設定檔的網頁:
 
<!doctype html>  
  
<html manifest="appcache.manifest">  
 <head>  
     <title>A Web Page</title>  
  <script src="library.js"></script>  
  <link rel="stylesheet" href="stylesheet.css">  
 </head>  
  
 <body onload="doSomething();">  
  <p>Results go here: <span id="results">Unknown</span></p>  
 </body>  
</html> 

 

 
 
 
您必須修改Web Server的設定,
 
下圖以Windows 7的IIS為例(Windows VISTA與後續新版本的IIS操作都差不多)。
 
請看下面兩張圖片的連續說明,
 
「MIME類型」必須設定「text/manifest」才能啟動網頁的Application Cache離線功能。
 
 
 


 
 
 
重點!如果Web Server(如IIS)不做好上圖的設定,MIME型態改為「text/manifest」。
 
瀏覽器將不會使用快取清單裡面的Manifest設定檔!
 
執行步驟如下:
1. 先瀏覽網頁(Manifest_01.html)。
2. 將網站關閉。模擬「離線(off-line)」的狀態,網站已經關閉,任何瀏覽器”理論上”無法連網(如下圖,左上方Chrome瀏覽器的畫面出現錯誤訊息)。
3. 故意重新瀏覽網頁(瀏覽器裡面按下F5按鍵),您可以發現下圖的狀態。(右下方的IE瀏覽器)原本網頁仍可運作,圖片也可以切換。
 
左上方的Chrome瀏覽器連不上網站,證明此時為「離線」狀態。因此離線快取的功能的確運作中!
 
 
 
 

本文內容,將會在2014年底,碁峰出版社推出的HTML5新書裡面

不好意思,因為內容將會出書,所以目前公開的東西都經過大量簡化
日後出書的話,針對每一個方法、屬性都會仔細解說
 
 
 
 
 
 
HTML5、CSS、JavaScript 網頁程式設計與 MCSD 70-480 認證教材
9789863475750

HTML5、CSS、JavaScript 網頁程式設計與 MCSD 70-480 認證教材

MIS2000 Lab. 周棟祥/吳進魯

  • 出版商:碁峰
  • 出版日期:2015-04-09
  • 台幣定價:
  • $480
  • 售價:7.9 折 $379
  • 語言:繁體中文
  • ISBN:9863475750
  • ISBN-13:9789863475750

 

 

 

**********************************************************************************************************************

我要買書:

PChome  http://24h.pchome.com.tw/books/prod/DJAV0S-A90060ASI

博客來  http://www.books.com.tw/products/0010671214

天瓏書局  https://www.tenlong.com.tw/items/9863475750?item_id=1003110






 
 

我將思想傳授他人, 他人之所得,亦無損於我之所有;

猶如一人以我的燭火點燭,光亮與他同在,我卻不因此身處黑暗。----Thomas Jefferson

寫信給我,不要私訊 --  mis2000lab (at) yahoo.com.台灣  或  school (at) mis2000lab.net



ASP.NET遠距教學、線上課程(Web Form + MVC)。 第二門 課程「四折」-- 以MVC課程 作優惠。
第一天課程, "完整" 試聽。  如不滿意  全額退費!
................   facebook社團   https://www.facebook.com/mis2000lab   ......................

................  YouTube (ASP.NET) 線上教學影片  http://goo.gl/rGLocQ

*********************************************************************************************

*** ASP.NET MVC線上課程 第一天 免費看 (5.5小時) *** 

************************************************************(歡迎索取,免費申請)*****

 

Blog文章 "附的範例" 無法下載,請看 這裡 ...... https://dotblogs.com.tw/mis2000lab/2016/03/14/2008_2015_mis2000lab_sample_download

請看我們的「售後服務」範圍(嚴格認定)

......................................................................................................................................................

...................................................................................................................................................... 

[遠距教學、教學影片] ASP.NET (Web Form) 課程 上線了!MIS2000Lab.主講

事先錄製好的影片,並非上課時側錄!   觀看影片時,有如我「一對一」跟您面對面講課

 

    MIS2000 Lab.  線上教學影片(YouTube) **免費觀賞**