日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

html5 初试 indexedDB

發布時間:2025/7/25 编程问答 17 豆豆
生活随笔 收集整理的這篇文章主要介紹了 html5 初试 indexedDB 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

indexedDB是存儲大量結構化數據的API,demo中用到的是異步API,麻煩的就是所有對indexedDB的操作都會發生一個異步的‘請求’,只要熟悉了API操作起來也很簡單。

大體流程是這樣

1.打開數據庫

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只有這一個方法 打開(數據庫名)
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 后創建ObjectStore 暫時用到兩個參數,數據庫&&主鍵
}
}
}


這樣就 創建/連接 了一個數據庫

2.創建交互對象 && 監聽dom事件 && 處理數據

然后就是要操作數據庫了

//插入數據 暫時只插入一列
var trans = db.transaction(["todo"], IDBTransaction.READ_WRITE);//創建transaction
var store = trans.objectStore("todo");//創建Store
//
要操作數據必須建立transaction 和 Store

var data = {
"text": todoText,
"adsid": new Date().getTime()
};//一個小數據 adsid是主鍵

var request = store.put(data); //‘強行’插入

request.onsuccess = function(e) {
//成功后執行一些操作
};

request.onerror = function(e) {
console.log("Error Adding: ", e);
}; //讀取數據
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的參數 keyRange是遍歷范圍 還可以添加遍歷方向參數
//
另一種方法是get() 這個就比較簡單了直接store.get('鍵值')就行

cursorRequest.onsuccess = function(e) {
var result = e.target.result;
if(!!result == false)
return;

console.log(result.value);
result.continue(); //循環讀取所有數據
}; //刪除數據
...
store.delete('鍵值')
...

?

出了一個小demo

<!DOCTYPE html>
<html>
<head>
<script>
var indexedDB = window.indexedDB || window.webkitIndexedDB ||
window.mozIndexedDB;

if ('webkitIndexedDB' in window) {
window.IDBTransaction = window.webkitIDBTransaction;
window.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" οnclick="addTodo(); return false;"/>
</body>
</html>

see also?Migrating your WebSQL DB to IndexedDB

轉載于:https://www.cnblogs.com/haner/archive/2012/02/03/2337060.html

總結

以上是生活随笔為你收集整理的html5 初试 indexedDB的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 嫩草综合 | 免费黄色在线视频 | 巨乳动漫美女 | 锦绣未央在线观看 | 刘亦菲毛片 | 少妇一晚三次一区二区三区 | 麻豆传媒在线看 | 亚洲最大视频网 | 国产成人无码精品久久 | 久久久久久久999 | 天天做天天爽 | 黄瓜视频色版 | 精品国产一区二区三区性色av | 免费看片视频 | 黑人一级大毛片 | 99成人在线 | 亚洲国产视频一区 | 欧美肉大捧一进一出免费视频 | 理论片中文 | 天天影视色 | 性折磨bdsm欧美激情另类 | 在线播放成人av | 国语对白做受欧美 | 影音先锋成人网 | 欧美一区二区三区久久综合 | 免费成人激情视频 | 日韩精品一区二区三区四区五区 | 精品久久久无码中文字幕边打电话 | 国产区福利| 美女被男生免费视频 | 99精品区 | 麻豆传媒网页 | 久久久久久伦理 | 在线观看你懂的网址 | 天天色天天射天天干 | 国产喷水吹潮视频www | 最新日韩av在线 | 97碰碰碰| 天天碰天天碰 | 日韩国产第一页 | 久久久夜夜夜 | 亚洲熟妇国产熟妇肥婆 | 美女毛片在线 | 一区福利| 国产资源站| 亚洲成人aa | 肉嫁高柳家 高清 | 91大神小宝寻花在线观看 | 一本视频在线 | 在线观看 亚洲 | 欧美成人免费播放 | 欧美日韩国产伦理 | 日本午夜一区二区 | 成人免费看高清电影在线观看 | 伊人色网站 | 四虎av影院 | 亚洲色图另类图片 | 91人人爱| 色偷偷五月天 | 欧美成人h版在线观看 | 青青视频一区二区 | 久久青青| 日韩av一卡 | 美女脱光衣服让男人捅 | 在线欧美一区二区 | 国产精品伦理 | 欧美一区二区三区公司 | 日产久久久久久 | 黄色录像网址 | 亚洲天堂欧美在线 | 久久精品6 | 女同毛片一区二区三区 | 黑料视频在线观看 | 亚洲欧美精品一区 | 亚洲精品乱码久久久久久9色 | 黄色欧美在线 | 四虎精品一区 | 成人午夜视频精品一区 | 欧美性另类| 国产三级国产精品国产专区50 | 亚欧洲精品视频 | 看久久 | 老女人性视频 | 日av一区 | 国产福利99| 伊人久久一区二区三区 | 国内精品嫩模av私拍在线观看 | 免费精品国产 | 成人淫片 | 亚洲狼人av | 亚洲最新在线观看 | 四虎免费视频 | www.日韩在线观看 | www.av在线.com| 二十四小时在线更新观看 | 久久午夜无码鲁丝片 | 三级第一页 | 欧美操穴视频 | 欧美黑人又粗又大的性格特点 |