html5 初試 indexedDB保舉
2016/12/30 9:41:51來(lái)源:互聯(lián)網(wǎng)
indexedDB是存儲(chǔ)大量結(jié)構(gòu)化數(shù)據(jù)的API,demo中用到的是異步API,麻煩的就是所有對(duì)indexedDB的操作都會(huì)發(fā)生一個(gè)異步的‘請(qǐng)求’,只要認(rèn)識(shí)了API操作起來(lái)也很簡(jiǎn)單。
大體流程是如許
1.打開(kāi)數(shù)據(jù)庫(kù)
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;
- }
- //這個(gè)就不詮釋了
- var request = indexedDB.open("adsageIDB"); //open : indexedDB只有這一個(gè)方法 打開(kāi)(數(shù)據(jù)庫(kù)名)
- 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í)用到兩個(gè)參數(shù),數(shù)據(jù)庫(kù)&&主鍵
- }
- }
- }
如許就 創(chuàng)建/連接 了一個(gè)數(shù)據(jù)庫(kù)
2.創(chuàng)建交互對(duì)象 && 監(jiān)聽(tīng)dom事件 && 處理數(shù)據(jù)
然后就是要操作數(shù)據(jù)庫(kù)了
javascript Code復(fù)制內(nèi)容到剪貼板
- //插入數(shù)據(jù) 臨時(shí)只插入一列
- 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()
- };//一個(gè)小數(shù)據(jù) adsid是主鍵
- var request = store.put(data); //‘強(qiáng)行’插入
- request.onsuccess = function(e) {
- //成功后實(shí)行一些操作
- };
- 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() 這個(gè)就比較簡(jiǎn)單了直接store.get('鍵值')就行
- cursorRequest.onsuccess = function(e) {
- var result = e.target.result;
- if(!!result == false)
- return;
- console.log(result.value);
- result.continue(); //循環(huán)讀取所稀有據(jù)
- };
javascript Code復(fù)制內(nèi)容到剪貼板
- //刪除數(shù)據(jù)
- ...
- store.delete('鍵值')
- ...
出了一個(gè)小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="增長(zhǎng)一個(gè) IDB" onclick="addTodo(); return false;"/>
- </body>
- </html>
以上這篇html5 初試 indexedDB(保舉)就是小編分享給大家的悉數(shù)內(nèi)容了,盼望能給大家一個(gè)參考,也盼望大家多多支持圖趣網(wǎng)。
原文地址:http://www.cnblogs.com/androidshouce/archive/2016/07/21/5690444.html
[教程作者:佚名]
免責(zé)聲明:本站文章系圖趣網(wǎng)整理發(fā)布,如需轉(zhuǎn)載,請(qǐng)注明出處,素材資料僅供個(gè)人學(xué)習(xí)與參考,請(qǐng)勿用于商業(yè)用途!
本文地址:http://pkvc.cn/tutorial/wd3364.html
本文地址:http://pkvc.cn/tutorial/wd3364.html
您可能還喜歡
- jquery Jcrop圖像裁切插件中文api文檔
- @media適配不同尺寸的手機(jī)
- 返回上一頁(yè)代碼的幾種寫(xiě)法
- Dreamweaver CC 2014新功能介紹
- 深入了解viewport和px
- 優(yōu)秀CSS代碼書(shū)寫(xiě)的10個(gè)規(guī)范
- 畫(huà)出你的風(fēng)格:HTML5創(chuàng)意畫(huà)板的設(shè)計(jì)教程
- Div中height:100%無(wú)效的解決辦法
- 網(wǎng)頁(yè)前端-網(wǎng)頁(yè)切圖命名規(guī)范
- 為網(wǎng)頁(yè)設(shè)計(jì)師而生的14個(gè)文本編輯器
這些是最新的
- 專訪:石墨文檔產(chǎn)品總監(jiān)羅穎
- UI設(shè)計(jì)不得不知的移動(dòng)端UI尺寸適
- 光音移動(dòng)設(shè)計(jì)規(guī)范 — 表單類
- 體驗(yàn)設(shè)計(jì)中的排序問(wèn)題
- 網(wǎng)頁(yè)設(shè)計(jì)精粹 網(wǎng)頁(yè)中那些迷人的按
- aliued:響應(yīng)式設(shè)計(jì)的現(xiàn)狀與趨勢(shì)
- 10個(gè)智能對(duì)象處理的ps技巧
- 網(wǎng)頁(yè)UI - 原子設(shè)計(jì)理論(上)
- 如何通過(guò)設(shè)計(jì)提升banner點(diǎn)擊率?
- 晉小彥視覺(jué)設(shè)計(jì)系列文章(二):全屏
最熱門的教程