HTML5+CSS3網(wǎng)頁設(shè)計基礎(chǔ)教程第7章-本地存儲_第1頁
HTML5+CSS3網(wǎng)頁設(shè)計基礎(chǔ)教程第7章-本地存儲_第2頁
HTML5+CSS3網(wǎng)頁設(shè)計基礎(chǔ)教程第7章-本地存儲_第3頁
HTML5+CSS3網(wǎng)頁設(shè)計基礎(chǔ)教程第7章-本地存儲_第4頁
HTML5+CSS3網(wǎng)頁設(shè)計基礎(chǔ)教程第7章-本地存儲_第5頁
已閱讀5頁,還剩19頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、第1頁第7章 本地存儲本章概述 本章的學(xué)習(xí)目標(biāo)主要內(nèi)容第2頁本章概述HTML5為客戶端存儲數(shù)據(jù)提出了理想的解決方案:如果存儲復(fù)雜的數(shù)據(jù),可以使用Web Database,該方法可以像客戶端程序一樣使用SQL語句對數(shù)據(jù)庫進(jìn)行操作;如果只是存儲簡單的Key/Value鍵值對,可以使用Web存儲。本章將從個方便介紹Web存儲和Web Database的使用。第3頁本章的學(xué)習(xí)目標(biāo)理解Cookie存儲機(jī)制的優(yōu)缺點(diǎn),從而了解為什么要用Web存儲;掌握使用Web存儲的方法,如檢查瀏覽器的兼容性、設(shè)置和獲取數(shù)據(jù)、放置數(shù)據(jù)泄露、Web存儲事件監(jiān)測等;掌握本地數(shù)據(jù)庫的使用,包括本地數(shù)據(jù)庫的基本概念、執(zhí)行查詢等 ;

2、掌握indexedDB數(shù)據(jù)庫的使用,包括數(shù)據(jù)庫連接、數(shù)據(jù)庫版本更新、創(chuàng)建對象倉庫、創(chuàng)建索引、使用事務(wù)、保存數(shù)據(jù)、獲取數(shù)據(jù)、檢索數(shù)據(jù)、統(tǒng)計操作等。第4頁主要內(nèi)容7.1 Web存儲 7.2 使用Web存儲 7.3 本地數(shù)據(jù)庫7.4 本章小結(jié) 第5頁7.1 Web存儲 7.1.1 Cookie存儲機(jī)制的優(yōu)缺點(diǎn)7.1.2 為什么要用Web存儲7.1.3 Web存儲的優(yōu)缺點(diǎn)第6頁7.1.1 Cookie存儲機(jī)制的優(yōu)缺點(diǎn)使用Cookie存儲信息的優(yōu)點(diǎn)有:簡單易用,瀏覽器負(fù)責(zé)發(fā)送數(shù)據(jù),且自動管理不同站點(diǎn)的Cookie。使用Cookie保存信息的缺點(diǎn)有:安全性差,存儲容量只有4KB,且存儲的鍵值對數(shù)量有限;用

3、戶可以將瀏覽器設(shè)置為禁用Cookie;另外,由于Cookie由請求來傳遞,因此傳遞大量數(shù)據(jù)時,效率顯得極低下。第7頁7.1.2 為什么要用Web存儲Web Storage存儲機(jī)制比傳統(tǒng)的Cookie更加強(qiáng)大,彌補(bǔ)了Cookie的許多缺點(diǎn),主要在兩方面做了加強(qiáng):第一,Web Storage提供了簡單易用的API接口,只需設(shè)置鍵值即可;第二,在存儲容量方面可以根據(jù)用戶分配的磁盤配額進(jìn)行存儲,能夠在每個用戶域存儲5MB10MB的內(nèi)容,用戶不僅可以存儲session,還可以存儲許多信息,如設(shè)置偏好、本地化的數(shù)據(jù)和離線數(shù)據(jù)等。Web Storage還提供了使用JavaScript編程的接口,開發(fā)者可以使

4、用JavaScript客戶端腳本實現(xiàn)許多以前只能在服務(wù)器端才能完成的工作。第8頁7.1.3 Web存儲的優(yōu)缺點(diǎn)Web存儲的優(yōu)點(diǎn)有以下幾點(diǎn):存儲空間更大:IE8下每個獨(dú)立的存儲空間為10M,其他瀏覽器實現(xiàn)略有不同,但都比Cookie要大很多。存儲內(nèi)容不會發(fā)送到服務(wù)器:當(dāng)設(shè)置了Cookie后,Cookie的內(nèi)容會隨著請求一并發(fā)送的服務(wù)器,這對于本地存儲的數(shù)據(jù)是一種帶寬浪費(fèi)。而Web Storage中的數(shù)據(jù)則僅僅是存在本地,不會與服務(wù)器發(fā)生任何交互。更多豐富易用的接口:Web Storage提供了一套更為豐富的接口,使得數(shù)據(jù)操作更為簡便。獨(dú)立的存儲空間:每個域(包括子域)有獨(dú)立的存儲空間,各個存儲空

5、間是完全獨(dú)立的,因此不會造成數(shù)據(jù)混亂。Web存儲的不足之處在于:瀏覽器為每個與分配獨(dú)立的存儲空間,不同域的存儲空間不能交叉訪問,但是在域B中嵌入域A的腳本依然可以訪問域B中的數(shù)據(jù);存儲在本地的數(shù)據(jù)未加密,容易造成隱私泄露。第9頁主要內(nèi)容7.1 Web存儲 7.2 使用Web存儲 7.3 本地數(shù)據(jù)庫7.4 本章小結(jié) 第10頁7.2 使用Web存儲 7.2.1 檢查瀏覽器的支持性7.2.2 設(shè)置和獲取數(shù)據(jù)7.2.3 Web存儲的其他操作7.2.4 Web存儲事件監(jiān)測7.2.5 制作簡單的網(wǎng)頁皮膚7.2.6 網(wǎng)站人氣值和在線人數(shù)統(tǒng)計第11頁7.2.1 檢查瀏覽器的支持性檢查瀏覽器對Web存儲的支持性

6、。if (typeof(Storage) = undefined) document.write(您的瀏覽器不支持Web存儲); else document.write(您的瀏覽器可以使用Web存儲);第12頁7.2.2 設(shè)置和獲取數(shù)據(jù)設(shè)置數(shù)據(jù)的語法格式如下:window.sessionStorage.setItem(myFirstKey,myFirstValue);獲取數(shù)據(jù)的語法格式如下:alert(window.sessionStorage.getItem(myFirstKey);第13頁7.2.3 Web存儲的其他操作獲取對象的長度:使用length屬性獲取目前Storage對象中存儲的

7、鍵值對的數(shù)量。注意的是,Storage對象是同源的,因此Storage對象的長度只反映同源情況下的長度。獲取指定位置的鍵:通過key(index)方法獲取一個指定位置的鍵。刪除數(shù)據(jù)項:通過removeItem(key)刪除數(shù)據(jù)項。如果數(shù)據(jù)存儲在鍵參數(shù)下,則調(diào)用此函數(shù)會將相應(yīng)的數(shù)據(jù)項刪除。如果鍵參數(shù)沒有對應(yīng)數(shù)據(jù),則不會執(zhí)行任何操作。清除所有數(shù)據(jù):通過clear()函數(shù)刪除存儲列表中的所有數(shù)據(jù)。第14頁7.2.4 Web存儲事件監(jiān)測在HTML5中,可以通過window對象的storage事件進(jìn)行監(jiān)聽并指定其事件處理函數(shù)的方法來定義當(dāng)其在其他頁面中修改sessionStorage或localStor

8、age中的值時所要執(zhí)行的處理,代碼如下:window.addEventListener(storage,function() /當(dāng)sessionStorage或localStorage中的值發(fā)生變動時所要執(zhí)行的處理 ,false); 第15頁7.2.5 制作簡單的網(wǎng)頁皮膚在訪問網(wǎng)站的時候,可以經(jīng)??吹?,一些網(wǎng)站允許用戶選擇自己喜歡的主題風(fēng)格,當(dāng)再次登錄的時候,網(wǎng)站將為該用戶顯示上次設(shè)置的主題風(fēng)格,這樣的主題風(fēng)格被稱為“皮膚”。在網(wǎng)頁設(shè)計中,一般用JavaScript動態(tài)設(shè)計網(wǎng)頁皮膚。對于皮膚配置數(shù)據(jù),就可以使用localStorage存儲。這樣,當(dāng)用戶再次登錄訪問的時候,程序?qū)⒆詣诱{(diào)用loca

9、lStorage數(shù)據(jù)來設(shè)置恢復(fù)頁面樣式?!?-3】制作簡單的網(wǎng)頁皮膚。第16頁7.2.6 網(wǎng)站人氣值和在線人數(shù)統(tǒng)計網(wǎng)站顯示著人氣值或當(dāng)前在線人數(shù)。其實實現(xiàn)原理大多是基于會話的統(tǒng)計。使用sessionStorage就可以作為會話計數(shù)器,localStorage則可以作為Web應(yīng)用訪問計數(shù)器。聲明一個localStorage計數(shù)變量,當(dāng)刷新頁面時,會看到計數(shù)器數(shù)值在增加。關(guān)閉瀏覽器窗口,然后重新打開,計數(shù)器還會在原來的基礎(chǔ)上繼續(xù)增加。而sessionStorage計數(shù)變量只能夠在當(dāng)前會話期間顯示頁面的訪問量,刷新頁面會看到計數(shù)器在增長,當(dāng)關(guān)閉瀏覽器時,然后再重新打開,計數(shù)器將被清除。【例7-4】網(wǎng)

10、站人氣值和在線人數(shù)統(tǒng)計。第17頁主要內(nèi)容7.1 Web存儲 7.2 使用Web存儲 7.3 本地數(shù)據(jù)庫7.4 本章小結(jié) 第18頁7.3 本地數(shù)據(jù)庫7.3.1 本地數(shù)據(jù)庫的基本概念7.3.2 用executeSql來執(zhí)行查詢7.3.3 創(chuàng)建一個簡單的數(shù)據(jù)庫7.3.4 綜合應(yīng)用點(diǎn)評功能第19頁7.3.1 本地數(shù)據(jù)庫的基本概念在HTML5中,可以向訪問本地文件那樣輕松對內(nèi)置數(shù)據(jù)庫進(jìn)行直接訪問。HTML5中內(nèi)置了兩種本地數(shù)據(jù)庫,一種是本節(jié)介紹的SQLLite,可以通過SQL語言來訪問的文件型SQL數(shù)據(jù)庫,另一種是被稱為indexedDB的NoSQL類型的數(shù)據(jù)庫。本書限于篇幅,僅對第一種數(shù)據(jù)庫進(jìn)行介紹。

11、對NoSQL感興趣的讀者可以閱讀其他相關(guān)資料。要在JavaScript腳本中使用SQLLite數(shù)據(jù)庫,有兩個必要步驟:(1)創(chuàng)建和訪問數(shù)據(jù)庫對象。(2)使用事務(wù)對數(shù)據(jù)庫進(jìn)行操作。第20頁7.3.2 用executeSql來執(zhí)行查詢在transaction的回調(diào)函數(shù)內(nèi)如何訪問數(shù)據(jù)庫。這里使用了作為參數(shù)傳遞給回調(diào)函數(shù)的transaction對象的executeSql方法,使用格式如下:transaction.executeSql(sqlquery,dataHandler,errorHandler);第21頁7.3.3 創(chuàng)建一個簡單的數(shù)據(jù)庫var db = openDatabase(db,1.0,T

12、estDB,2*1024*1024);var msg;db.transaction(function(tx)tx.executeSql(CREATE TABLE IF NOT EXISTS logs(id unique,log);tx.executeSql(INSERT INTO logs(id,log) VALUES(1,foobar);tx.executeSql(INSERT INTO logs(id,log) VALUES(2,logmsg);msg = 完成消息創(chuàng)建和插入行操作。;document.querySelector(#status).innerHTML = msg;);db.

13、transaction(function(tx) tx.executeSql(SELECT * FROM logs,function(tx,results)var len = results.rows.length,i;msg = 查詢行數(shù):+len+;document.querySelector(#status).innerHTML += msg;for(i=0;ilen;i+)msg=+results.rows.item(i).log + ;document.querySelector(#status).innerHTML += msg;,null););第22頁7.3.4 綜合應(yīng)用點(diǎn)評功能詳見【例7-8】簡單點(diǎn)評功能。第23頁主要內(nèi)容7.1 Web存

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論