html5 初試 indexedDB(推薦)
發(fā)布時間:2016-07-21 10:00:03 作者:佚名
我要評論

下面小編就為大家?guī)硪黄猦tml5 初試 indexedDB(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,祝大家游戲愉快哦
indexedDB是存儲大量結(jié)構(gòu)化數(shù)據(jù)的API,demo中用到的是異步API,麻煩的就是所有對indexedDB的操作都會發(fā)生一個異步的‘請求’,只要熟悉了API操作起來也很簡單。
大體流程是這樣
1.打開數(shù)據(jù)庫
JavaScript Code復(fù)制內(nèi)容到剪貼板
- var indexedDB = window.indexedDB || window.webkitIndexedDB || window.mozIndexedDB;
- if ('webkitIndexedDB' in window) {
- window.IDBTransaction = window.webkitIDBTransaction;
- window.IDBKeyRange = window.webkitIDBKeyRange;
- }
- //這個就不解釋了
- var request = indexedDB.open("adsageIDB"); //open : indexedDB只有這一個方法 打開(數(shù)據(jù)庫名)
- request.onsuccess = function(e) { //異步
- var v = "1.00";
- var db = e.target.result;
- if (v!= db.version) {
- var setVrequest = db.setVersion(v);
- setVrequest.onsuccess = function(e) { //異步
- if(db.objectStoreNames.contains("todo")) {
- db.deleteObjectStore("todo");
- }
- var store = db.createObjectStore("todo", {keyPath: "adsid"});//onsuccess 后創(chuàng)建ObjectStore 暫時用到兩個參數(shù),數(shù)據(jù)庫&&主鍵
- }
- }
- }
這樣就 創(chuàng)建/連接 了一個數(shù)據(jù)庫
2.創(chuàng)建交互對象 && 監(jiān)聽dom事件 && 處理數(shù)據(jù)
然后就是要操作數(shù)據(jù)庫了
JavaScript Code復(fù)制內(nèi)容到剪貼板
- //插入數(shù)據(jù) 暫時只插入一列
- var trans = db.transaction(["todo"], IDBTransaction.READ_WRITE);//創(chuàng)建transaction
- var store = trans.objectStore("todo");//創(chuàng)建Store
- //要操作數(shù)據(jù)必須建立transaction 和 Store
- var data = {
- "text": todoText,
- "adsid": new Date().getTime()
- };//一個小數(shù)據(jù) adsid是主鍵
- var request = store.put(data); //‘強行’插入
- request.onsuccess = function(e) {
- //成功后執(zhí)行一些操作
- };
- request.onerror = function(e) {
- console.log("Error Adding: ", e);
- };
JavaScript Code復(fù)制內(nèi)容到剪貼板
- //讀取數(shù)據(jù)
- var trans = db.transaction(["todo"], IDBTransaction.READ_WRITE);
- var store = trans.objectStore("todo");
- var keyRange = IDBKeyRange.lowerBound(0);
- var cursorRequest = store.openCursor(keyRange);
- //這里用到指針cursor ,openCursor的參數(shù) keyRange是遍歷范圍 還可以添加遍歷方向參數(shù)
- //另一種方法是get() 這個就比較簡單了直接store.get('鍵值')就行
- cursorRequest.onsuccess = function(e) {
- var result = e.target.result;
- if(!!result == false)
- return;
- console.log(result.value);
- result.continue(); //循環(huán)讀取所有數(shù)據(jù)
- };
JavaScript Code復(fù)制內(nèi)容到剪貼板
- //刪除數(shù)據(jù)
- ...
- store.delete('鍵值')
- ...
出了一個小demo
XML/HTML Code復(fù)制內(nèi)容到剪貼板
- <!DOCTYPE html>
- <html>
- <head>
- <script>
- var indexedDB = window.indexedDB || window.webkitIndexedDB ||
- window.mozIndexedDB;
- if ('webkitIndexedDB' in window) {
- windowwindow.IDBTransaction = window.webkitIDBTransaction;
- windowwindow.IDBKeyRange = window.webkitIDBKeyRange;
- }
- adsageIDB = {};
- adsageIDB.db = null;
- adsageIDB.onerror = function(e) {
- console.log(e);
- };
- adsageIDB.open = function() {
- var request = indexedDB.open("adsageIDB");
- request.onsuccess = function(e) {
- var v = "1.00";
- adsageIDB.db = e.target.result;
- var db = adsageIDB.db;
- if (v!= db.version) {
- var setVrequest = db.setVersion(v);
- setVrequest.onerror = adsageIDB.onerror;
- setVrequest.onsuccess = function(e) {
- if(db.objectStoreNames.contains("todo")) {
- db.deleteObjectStore("todo");
- }
- var store = db.createObjectStore("todo",
- {keyPath: "adsid"});
- adsageIDB.getAllTodoItems();
- };
- }
- else {
- adsageIDB.getAllTodoItems();
- }
- };
- request.onerror = adsageIDB.onerror;
- }
- adsageIDB.addTodo = function(todoText) {
- var db = adsageIDB.db;
- var trans = db.transaction(["todo"], IDBTransaction.READ_WRITE);
- var store = trans.objectStore("todo");
- var data = {
- "text": todoText,
- "adsid": new Date().getTime()
- };
- var request = store.put(data);
- request.onsuccess = function(e) {
- adsageIDB.getAllTodoItems();
- };
- request.onerror = function(e) {
- console.log("Error Adding: ", e);
- };
- };
- adsageIDB.deleteTodo = function(id) {
- var db = adsageIDB.db;
- var trans = db.transaction(["todo"], IDBTransaction.READ_WRITE);
- var store = trans.objectStore("todo");
- var request = store.delete(id);
- request.onsuccess = function(e) {
- adsageIDB.getAllTodoItems();
- };
- request.onerror = function(e) {
- console.log("Error Adding: ", e);
- };
- };
- adsageIDB.getAllTodoItems = function() {
- var todos = document.getElementById("todoItems");
- todos.innerHTML = "";
- var db = adsageIDB.db;
- var trans = db.transaction(["todo"], IDBTransaction.READ_WRITE);
- var store = trans.objectStore("todo");
- var keyRange = IDBKeyRange.lowerBound(0);
- var cursorRequest = store.openCursor(keyRange);
- cursorRequest.onsuccess = function(e) {
- var result = e.target.result;
- if(!!result == false)
- return;
- renderTodo(result.value);
- result.continue();
- };
- cursorRequest.onerror = adsageIDB.onerror;
- };
- function renderTodo(row) {
- var todos = document.getElementById("todoItems");
- var li = document.createElement("li");
- var a = document.createElement("a");
- var t = document.createTextNode(row.text);
- a.addEventListener("click", function() {
- adsageIDB.deleteTodo(row.adsid);
- }, false);
- a.textContent = " [刪除]";
- li.appendChild(t);
- li.appendChild(a);
- todos.appendChild(li)
- }
- function addTodo() {
- var todo = document.getElementById("todo");
- adsageIDB.addTodo(todo.value);
- todo.value = "";
- }
- function init() {
- adsageIDB.open();
- }
- window.addEventListener("DOMContentLoaded", init, false);
- </script>
- </head>
- <body>
- <ul id="todoItems"></ul>
- <input type="text" id="todo" name="todo" placeholder="adsageIDB text?" />
- <input type="submit" value="增加一個 IDB" onclick="addTodo(); return false;"/>
- </body>
- </html>
以上這篇html5 初試 indexedDB(推薦)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
原文地址:http://www.cnblogs.com/androidshouce/archive/2016/07/21/5690444.html
相關(guān)文章
html5中l(wèi)ocalStorage本地存儲的簡單使用
我們在做頁面時會用到本地存儲的時候,今天說說localStorage本地存儲。感興趣的朋友一起學(xué)習(xí)吧2017-06-16- html5的兩種存儲技術(shù)的最大區(qū)別就是生命周期,接下來通過本文給大家分享HTML5 LocalStorage 本地存儲刷新值還在問題以及使用方法小結(jié),需要的的朋友參考下本文吧2017-03-10
- 本篇文章主要介紹了HTML5 LocalStorage 本地存儲 ,HTML5 storage提供了一種方式讓網(wǎng)站能夠把信息存儲到你本地的計算機上,并再以后需要的時候進(jìn)行獲取。有興趣的可以了解2016-12-23
- 這篇文章主要介紹了html5本地存儲 localStorage操作使用詳解的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-09-20
- 這篇文章主要介紹了Html5 web本地存儲實例詳解的相關(guān)資料,需要的朋友可以參考下2016-07-28
- 這篇文章主要為大家詳細(xì)介紹了HTML5本地存儲之Web Storage的相關(guān)資料,Web Storage如何用JSON存儲多個數(shù)據(jù),感興趣的小伙伴們可以參考一下2016-07-04
HTML5中indexedDB 數(shù)據(jù)庫的使用實例
本篇文章主要介紹了HTML5中indexedDB 數(shù)據(jù)庫的使用實例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-11深入解析HTML5的IndexedDB索引數(shù)據(jù)庫
這篇文章主要介紹了深入解析HTML5中的IndexedDB索引數(shù)據(jù)庫,包括事務(wù)鎖等基本功能的相關(guān)使用示例,需要的朋友可以參考下2015-09-14- IndexedDB 是一種低級API,用于客戶端存儲大量結(jié)構(gòu)化數(shù)據(jù)(包括, 文件/ blobs)。下面通過本文重點給大家介紹HTML5本地存儲之IndexedDB的相關(guān)知識,感興趣的朋友一起看看吧2017-06-16