基于Firefox 10的IndexedDB实例演示

今天做一个IndexedDB(以下简称IDB)的demo,运行环境是Firefox 10。

创新互联公司服务项目包括建昌网站建设、建昌网站制作、建昌网页制作以及建昌网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,建昌网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到建昌省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

DEMO演示链接 (firefox 10+ only)

我们做一个阅读列表的页面,可以让用户把任意网址存入这个阅读列表中,并为每一个网址起一个名字,也可以随时删除,且列表可以按网址自动去重。

正如上一篇文章介绍的步骤,我们先初始化数据库,然后建表,然后把添加/删除/读取网址的事件和数据库操作绑定在一起。

首先是html代码:

 
 
 
  1. _body onload="init()"> 
  2.     _button onclick="clickAddBtn()">Add_/button> 
  3.     _ul id="list">_/ul> 
  4. _/body> 

为了演示方便,我们引入jQuery作界面处理,再声明一个全局变量db,作为数据库连接的句柄;再声明一个全局变量list,作为网页中列表元素的jQuery句柄。

 
 
 
  1. var db;  
  2. var list = $('#list'); 

然后定义数据库初始化的行数init

 
 
 
  1. function init() {  
  2.     var req = window.mozIndexedDB.open('readinglist', '1.0');  
  3.     req.onsuccess = function (e) {  
  4.         db = this.result;  
  5.         // TODO: 连接成功后展示列表  
  6.     };  
  7.     req.onupgradeneeded = function (e) {  
  8.         db = this.result;  
  9.         // TODO: 版本不同时创建一个新的object store  
  10.     };  

这段代码的作用是初始化数据库(readinglist)连接,并在第一次连接数据库时创建表(links)。我们把展示列表的函数定义为showList(),把创建表的代码也补充完整,即:

 
 
 
  1. function init() {  
  2.     var req = window.mozIndexedDB.open('readinglist', '1.0');  
  3.     req.onsuccess = function (e) {  
  4.         db = this.result;  
  5.         showList();  
  6.     };  
  7.     req.onupgradeneeded = function (e) {  
  8.         db = this.result;  
  9.         db.createObjectStore('links', {keyPath: 'url'});  
  10.     };  

然后我们定义添加/删除/展示链接的函数:add(title, url)/remove(url)/showList()

 
 
 
  1. function add(title, url) {  
  2.     var link = {  
  3.         title: title,  
  4.         url: url  
  5.     }; // 创建要存储的对象  
  6.     var transaction = db.transaction('links', IDBTransaction.READ_WRITE);  
  7.     var store = transaction.objectStore('links');  
  8.     var req = store.put(link); // put的作用是key存在时做更新处理,不存在是做添加处理  
  9.     req.onsuccess = showList; // 添加成功后重新展示列表  
  10. }  
  11.  
  12. function remove(url) {  
  13.     var transaction = db.transaction('links', IDBTransaction.READ_WRITE);  
  14.     var store = transaction.objectStore('links');  
  15.     var req = store.delete(url); // 删除此链接  
  16.     req.onsuccess = showList; // 删除成功后重新展示列表  
  17. }  
  18.  
  19. function showList() {  
  20.     // TODO: clear element: #list  
  21.  
  22.     var transaction = db.transaction('links');  
  23.     var store = transaction.objectStore('links');  
  24.     var range = IDBKeyRange.lowerBound(0); // 创建关键字范围描述  
  25.     var req = store.openCursor(range); // 创建在上述范围内遍历的游标  
  26.     req.onsuccess = function (e) {  
  27.         var result = this.result;  
  28.         if (result) {  
  29.             var link = result.value;  
  30.             // TODO: append this link to element: #list  
  31.             result.continue();  
  32.         }  
  33.     };  

注意这里的IDBKeyRange和store.openCursor是用来遍历列表的,前者确定遍历的范围,后者根据前者的范围逐条触发onsuccess事件,这里定义的遍历范围是大于0,即所有非空的url,其实所有js类型的值都是可以在一起比大小的,如果想测试比较任意两个key的大小,可以运行函数window.mozIndexedDB.cmp(any first, any second)。

最后,我们把最后两个TODO的部分补充完整,再把界面上的事件绑定好。编码工作就完成了。

 
 
 
  1. function showList() {  
  2.     list.empty();  
  3.  
  4.     var transaction = db.transaction('links');  
  5.     var store = transaction.objectStore('links');  
  6.     var range = IDBKeyRange.lowerBound(0); // 创建关键字范围描述  
  7.     var req = store.openCursor(range); // 创建在上述范围内遍历的游标  
  8.     req.onsuccess = function (e) {  
  9.         var result = this.result;  
  10.         if (result) {  
  11.             var link = result.value;  
  12.             appendLink(link);  
  13.             result.continue();  
  14.         }  
  15.     };  
  16. }  
  17.  
  18. function appendLink(link) {  
  19.     var url = link.url;  
  20.     var title = link.title;  
  21.     var li = $('_li>_a href="#" target="_blank">_/a> _button>X_/button>_/li>');  
  22.     li.find('a').attr('title', title).attr('href', url).text(title);  
  23.     li.find('button').click(function (e) {  
  24.         remove(link.url);  
  25.     });  
  26.     list.append(li);  
  27. }  
  28.  
  29. function clickAddBtn(e) {  
  30.     var title = prompt('please input the title') || '[No title]';  
  31.     var url = prompt('please input the url', 'http://');  
  32.     if (title && url) {  
  33.         add(title, url);  
  34.     }  

DEMO演示链接 (firefox 10+ only)

下一篇讨论webkit下使用IDB的注意事项,并提供兼容问题的解决办法。

【系列文章】

  1. IndexedDB的JS接口设计详解
  2. 浅析IndexedDB存数结构
  3. 调试IndexedDB应用程序

原文:http://bulaoge.net/topic.blg?dmn=g3g4&tid=2335030#Content

网页标题:基于Firefox 10的IndexedDB实例演示
网页地址:http://www.mswzjz.cn/qtweb/news46/290096.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能