明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

H5的本地存儲(chǔ)與本地?cái)?shù)據(jù)庫(kù)詳細(xì)說明

[摘要]這次給大家?guī)鞨5的本地存儲(chǔ)和本地?cái)?shù)據(jù)庫(kù)詳細(xì)介紹,使用H5的本地存儲(chǔ)和本地?cái)?shù)據(jù)庫(kù)的注意事項(xiàng)有哪些,下面就是實(shí)戰(zhàn)案例,一起來看一下。本地存儲(chǔ)1.1 本地存儲(chǔ)由來的背景由于HTML4時(shí)代Cookie的大小、格式、存儲(chǔ)數(shù)據(jù)格式等限制,網(wǎng)站應(yīng)用如果想在瀏覽器端存儲(chǔ)用戶的部分信息,那么只能借助于Cookie...
這次給大家?guī)鞨5的本地存儲(chǔ)和本地?cái)?shù)據(jù)庫(kù)詳細(xì)介紹,使用H5的本地存儲(chǔ)和本地?cái)?shù)據(jù)庫(kù)的注意事項(xiàng)有哪些,下面就是實(shí)戰(zhàn)案例,一起來看一下。

本地存儲(chǔ)

1.1 本地存儲(chǔ)由來的背景

由于HTML4時(shí)代Cookie的大小、格式、存儲(chǔ)數(shù)據(jù)格式等限制,網(wǎng)站應(yīng)用如果想在瀏覽器端存儲(chǔ)用戶的部分信息,那么只能借助于Cookie。但是Cookie的這些限制,也就導(dǎo)致了Cookie只能存儲(chǔ)一些ID之類的標(biāo)識(shí)符等簡(jiǎn)單的數(shù)據(jù)。

下面是Cookie的限制:

大多數(shù)瀏覽器支持最大為 4096 字節(jié)的 Cookie。

瀏覽器還限制站點(diǎn)可以在用戶計(jì)算機(jī)上存儲(chǔ)的 Cookie 的數(shù)量。大多數(shù)瀏覽器只允許每個(gè)站點(diǎn)存儲(chǔ) 20 個(gè)Cookie;如果試圖存儲(chǔ)更多 Cookie,則最舊的 Cookie 便會(huì)被丟棄。

有些瀏覽器還會(huì)對(duì)它們將接受的來自所有站點(diǎn)的 Cookie 總數(shù)作出絕對(duì)限制,通常為 300 個(gè)。

Cookie默認(rèn)情況都會(huì)隨著Http請(qǐng)求發(fā)送到后臺(tái)服務(wù)器,但并不是所有請(qǐng)求都需要Cookie的,比如:js、css、圖片等請(qǐng)求則不需要Cookie。

為了破解Cookie的一系列限制,HTML5通過JS的新的API就能直接存儲(chǔ)大量的數(shù)據(jù)到客戶端瀏覽器,而且支持復(fù)雜的本地?cái)?shù)據(jù)庫(kù),讓JS更有效率。

html5支持兩種的WebStorage:

永久性的本地存儲(chǔ)(localStorage)

會(huì)話級(jí)別的本地存儲(chǔ)(sessionStorage)

1.2 永久性的本地存儲(chǔ):localStorage

在最新的JS的API中增加了localStorage對(duì)象,便于用戶存儲(chǔ)永久存儲(chǔ)的Web端的數(shù)據(jù)。而且數(shù)據(jù)不會(huì)隨著Http請(qǐng)求發(fā)送到后臺(tái)服務(wù)器,而且存儲(chǔ)數(shù)據(jù)的大小基本不用考慮,因?yàn)樵贖tml5的標(biāo)準(zhǔn)中要求瀏覽器至少要支持到4MB.所以,這完全是顛覆了Cookie的限制,為Web應(yīng)用在本地存儲(chǔ)復(fù)雜的用戶痕跡數(shù)據(jù)提供非常方便的技術(shù)支持。接下來就將介紹localStorage的常用的方法。

localStorage提供了四個(gè)方法來輔助我們進(jìn)行對(duì)本地存儲(chǔ)做相關(guān)操作。

setItem(key,value)添加本地存儲(chǔ)數(shù)據(jù)。兩個(gè)參數(shù),非常簡(jiǎn)單就不說了。

getItem(key)通過key獲取相應(yīng)的Value。

removeItem(key)通過key刪除本地?cái)?shù)據(jù)。

clear()清空數(shù)據(jù)。

代碼如下:

<script type="text/javascript">
    //添加key-value 數(shù)據(jù)到 sessionStorage
    localStorage.setItem("demokey", "http://www.shiyanlou.com");
    //通過key來獲取value
    var dt = localStorage.getItem("demokey");
    alert(dt);
    //清空所有的key-value數(shù)據(jù)。
    //localStorage.clear();
    alert(localStorage.length);
</script>

1.3 會(huì)話級(jí)別的本地存儲(chǔ):sessionStorage

在HTML5中增加了一個(gè)Js對(duì)象:sessionStorage;通過此對(duì)象可以直接操作存儲(chǔ)在瀏覽器中的會(huì)話級(jí)別的WebStorage。存儲(chǔ)在sessionStorage中的數(shù)據(jù)首先是Key-Value形式的,另外就是它跟瀏覽器當(dāng)前會(huì)話相關(guān),當(dāng)會(huì)話結(jié)束后,數(shù)據(jù)會(huì)自動(dòng)清除,跟未設(shè)置過期時(shí)間的Cookie類似。

sessionStorage提供了四個(gè)方法來輔助我們進(jìn)行對(duì)本地存儲(chǔ)做相關(guān)操作。

setItem(key,value)添加本地存儲(chǔ)數(shù)據(jù)。兩個(gè)參數(shù),非常簡(jiǎn)單就不說了。

getItem(key)通過key獲取相應(yīng)的Value。

removeItem(key)通過key刪除本地?cái)?shù)據(jù)。

clear()清空數(shù)據(jù)。

代碼如下:

<script type="text/javascript">
    //添加key-value 數(shù)據(jù)到 sessionStorage
    sessionStorage.setItem("demokey", "http://blog.itjeek.com");
    //通過key來獲取value
    var dt = sessionStorage.getItem("demokey");
    alert(dt);
    //清空所有的key-value數(shù)據(jù)。
    //sessionStorage.clear();
    alert(sessionStorage.length);
</script>

1.4 強(qiáng)大的本地?cái)?shù)據(jù)

雖然HTML5已經(jīng)提供了功能強(qiáng)大的localStorage和sessionStorage,但是他們兩個(gè)都只能提供存儲(chǔ)簡(jiǎn)單數(shù)據(jù)結(jié)構(gòu)的數(shù)據(jù),對(duì)于復(fù)雜的Web應(yīng)用的數(shù)據(jù)卻無能為力。逆天的是HTML5提供了一個(gè)瀏覽器端的數(shù)據(jù)庫(kù)支持,允許我們直接通JS的API在瀏覽器端創(chuàng)建一個(gè)本地的數(shù)據(jù)庫(kù),而且支持標(biāo)準(zhǔn)的SQL的CRUD操作,讓離線的Web應(yīng)用更加方便的存儲(chǔ)結(jié)構(gòu)化的數(shù)據(jù)。接下里介紹一下本地?cái)?shù)據(jù)的相關(guān)API和用法。

操作本地?cái)?shù)據(jù)庫(kù)的最基本的步驟是:

第一步:openDatabase方法:創(chuàng)建一個(gè)訪問數(shù)據(jù)庫(kù)的對(duì)象。

第二步:使用第一步創(chuàng)建的數(shù)據(jù)庫(kù)訪問對(duì)象來執(zhí)行transaction方法,通過此方法可以設(shè)置一個(gè)開啟事務(wù)成功的事件響應(yīng)方法,在事件響應(yīng)方法中可以執(zhí)行SQL.

第三步:通過executeSql方法執(zhí)行查詢,當(dāng)然查詢可以是:CRUD。

接下來分別介紹一下相關(guān)的方法的參數(shù)和用法。

1.4.1 openDatabase方法

//Demo:獲取或者創(chuàng)建一個(gè)數(shù)據(jù)庫(kù),如果數(shù)據(jù)庫(kù)不存在那么創(chuàng)建之

var dataBase = openDatabase(“student”, “1.0”, “學(xué)生表”, 1024 * 1024, function () { });


openDatabase方法打開一個(gè)已經(jīng)存在的數(shù)據(jù)庫(kù),如果數(shù)據(jù)庫(kù)不存在,它還可以創(chuàng)建數(shù)據(jù)庫(kù)。幾個(gè)參數(shù)意義分別是:

數(shù)據(jù)庫(kù)名稱。

數(shù)據(jù)庫(kù)的版本號(hào),目前來說傳個(gè)1.0就可以了,當(dāng)然可以不填;

對(duì)數(shù)據(jù)庫(kù)的描述。

設(shè)置分配的數(shù)據(jù)庫(kù)的大。▎挝皇莐b)。

回調(diào)函數(shù)(可省略)。

初次調(diào)用時(shí)創(chuàng)建數(shù)據(jù)庫(kù),以后就是建立連接了。

1.4.2 db.transaction方法

可以設(shè)置一個(gè)回調(diào)函數(shù),此函數(shù)可以接受一個(gè)參數(shù)就是我們開啟的事務(wù)的對(duì)象。然后通過此對(duì)象可以執(zhí)行SQL腳本。

<head>
 <script src="Scripts/jquery-1.5.1.js" type="text/javascript"></script>
    <script type="text/javascript">
        function initDatabase() {
            var db = getCurrentDb();//初始化數(shù)據(jù)庫(kù)
            if(!db) {alert("您的瀏覽器不支持HTML5本地?cái)?shù)據(jù)庫(kù)");return;}
            db.transaction(function (trans) {//啟動(dòng)一個(gè)事務(wù),并設(shè)置回調(diào)函數(shù)
                //執(zhí)行創(chuàng)建表的Sql腳本
                trans.executeSql("create table if not exists Demo(uName text null,title text null,words text null)", [], function (trans, result) {
                }, function (trans, message) {//消息的回調(diào)函數(shù)alert(message);});
            }, function (trans, result) {
            }, function (trans, message) {
            });
        }
        $(function () {//頁(yè)面加載完成后綁定頁(yè)面按鈕的點(diǎn)擊事件
            initDatabase();
            $("#btnSave").click(function () {
                var txtName = $("#txtName").val();
                var txtTitle = $("#txtTitle").val();
                var txtWords = $("#txtWords").val();
                var db = getCurrentDb();
                //執(zhí)行sql腳本,插入數(shù)據(jù)
                db.transaction(function (trans) {
                    trans.executeSql("insert into Demo(uName,title,words) values(?,?,?) ", [txtName, txtTitle, txtWords], function (ts, data) {
                    }, function (ts, message) {
                        alert(message);
                    });
                });
                showAllTheData();
            });
        });
        function getCurrentDb() {
            //打開數(shù)據(jù)庫(kù),或者直接連接數(shù)據(jù)庫(kù)參數(shù):數(shù)據(jù)庫(kù)名稱,版本,概述,大小
            //如果數(shù)據(jù)庫(kù)不存在那么創(chuàng)建之
            var db = openDatabase("myDb", "1.0", "it's to save demo data!", 1024 * 1024); ;
            return db;
        }
        //顯示所有數(shù)據(jù)庫(kù)中的數(shù)據(jù)到頁(yè)面上去
        function showAllTheData() {
            $("#tblData").empty();
            var db = getCurrentDb();
            db.transaction(function (trans) {
                trans.executeSql("select * from Demo ", [], function (ts, data) {
                    if (data) {
                        for (var i = 0; i < data.rows.length; i++) {
                            appendDataToTable(data.rows.item(i));//獲取某行數(shù)據(jù)的json對(duì)象
                        }
                    }
                }, function (ts, message) {alert(message);var tst = message;});
            });
        }
        function appendDataToTable(data) {//將數(shù)據(jù)展示到表格里面
            //uName,title,words
            var txtName = data.uName;
            var txtTitle = data.title;
            var words = data.words;
            var strHtml = "";
            strHtml += "<tr>";
            strHtml += "<td>"+txtName+"</td>";
            strHtml += "<td>" + txtTitle + "</td>";
            strHtml += "<td>" + words + "</td>";
            strHtml += "</tr>";
            $("#tblData").append(strHtml);
        }
    </script>
</head>
    <body>
        <table>
            <tr>
                <td>用戶名:</td>
                <td><input type="text" name="txtName" id="txtName" required/></td>
            </tr>
               <tr>
                <td>標(biāo)題:</td>
                <td><input type="text" name="txtTitle" id="txtTitle" required/></td>
            </tr>
            <tr>
                <td>留言:</td>
                <td><input type="text" name="txtWords" id="txtWords" required/></td>
            </tr>
        </table>
        <input type="button" value="保存" id="btnSave"/>
        <hr/>
        <input type="button" value="展示所喲數(shù)據(jù)" onclick="showAllTheData();"/>
        <table id="tblData">
        </table>
    </body>
</html>

相信看了這些案例你已經(jīng)掌握了方法,更多精彩請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!

相關(guān)閱讀:

HTML的table鼠標(biāo)拖拽排序該如何實(shí)現(xiàn)

html屬于什么文件html的文件該如何打開

html怎樣實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn)時(shí)傳遞參數(shù)

以上就是H5的本地存儲(chǔ)和本地?cái)?shù)據(jù)庫(kù)詳細(xì)介紹的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!


網(wǎng)站建設(shè)是一個(gè)廣義的術(shù)語,涵蓋了許多不同的技能和學(xué)科中所使用的生產(chǎn)和維護(hù)的網(wǎng)站。