版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、HTML5+CSS3 Web前端开发技术前端开发技术第11章 HTML5的IndexedDB数据库(HTML5与CSS3 Web前端开发技术)HTML5+CSS3 Web前端开发技术前端开发技术HTML5+CSS3 Web前端开发技术前端开发技术HTML5+CSS3 Web前端开发技术前端开发技术HTML5+CSS3 Web前端开发技术前端开发技术11.2 创立数据库创立数据库v 创立和连接数据库创立和连接数据库v IndexedDB API中的的中的的open()方法,用方法,用于创立或翻开指定的数据库,语法格式如下。于创立或翻开指定的数据库,语法格式如下。v var dbRequest =
2、v indexedDB.open(dbName,dbVersion);HTML5+CSS3 Web前端开发技术前端开发技术11.2 创立数据库创立数据库2. IndexedDB 数据库中的对象定义数据库中的对象定义 IndexedDB 数据库包括数据库包括indexedDB、IDBTransaction 、IDBKeyRange、IDBCursor等等对象,为了确保脚本代码在各浏览器中兼容,应当在使用数对象,为了确保脚本代码在各浏览器中兼容,应当在使用数据库之前统一定义,代码如下。据库之前统一定义,代码如下。window.indexedDB=window.indexedDB|window.we
3、bkitIndexedDB;window.IDBTransaction=window.IDBTransaction|window.webkitIDBTransaction|;window.IDBKeyRange= window.IDBKeyRange|window.webkitIDBKeyRange;window.IDBCursor= window.IDBCursor|window.webkitIDBCursor;HTML5+CSS3 Web前端开发技术前端开发技术11.2 创立数据库创立数据库3. 删除数据库删除数据库 删除现有数据库,可以调用删除现有数据库,可以调用 deleteDatab
4、ase()方法,方法,该方法的使用和该方法的使用和open()方法类似,将要删除的数据库名称方法类似,将要删除的数据库名称作为参数,代码如下。作为参数,代码如下。function deleteDatabase() var deleteDbRequest = window.indexedDB.deleteDatabase(dbName); deleteDbRequest.onsuccess = function (e) /成功处理成功处理 ; deleteDbRequest.onerror = function (e) /错误处理错误处理 ;HTML5+CSS3 Web前端开发技术前端开发技术1
5、1.2 创立数据库创立数据库4. 连接数据库的完整例如连接数据库的完整例如HTML5+CSS3 Web前端开发技术前端开发技术11.3 数据库的版本更新和事务处理数据库的版本更新和事务处理1. 版本更新版本更新连接成功的数据库还不能执行任何数据操作。在使连接成功的数据库还不能执行任何数据操作。在使用用IndexedDB 数据库的时候,所有数据的操作数据库的时候,所有数据的操作都需要在一个事务内部执行。而对于对象仓库与索都需要在一个事务内部执行。而对于对象仓库与索引的操作,类似于关系数据库中表结构或索引的操引的操作,类似于关系数据库中表结构或索引的操作,必须在版本更新事务内部进行。作,必须在版本
6、更新事务内部进行。例如例如11-2实现的是一个版本更新的测试功能。实现的是一个版本更新的测试功能。HTML5+CSS3 Web前端开发技术前端开发技术11.3 数据库的版本更新和事务处理数据库的版本更新和事务处理2.事务处理事务处理创立对象仓库与索引、对象仓库执行所有读取和写创立对象仓库与索引、对象仓库执行所有读取和写入操作的操作必须在事务中进行。入操作的操作必须在事务中进行。事务具有三种模式事务具有三种模式: readonly:提供对某个对象仓库的只读访问:提供对某个对象仓库的只读访问,在查询对象仓库时使用。,在查询对象仓库时使用。 readwrite:提供对某个对象仓库的读取和写:提供对某
7、个对象仓库的读取和写入权限。入权限。 versionchange:提供读取和写入权限来修:提供读取和写入权限来修改对象仓库定义,或者创立一个新的对象仓库。改对象仓库定义,或者创立一个新的对象仓库。数据库的事务处理使用数据库的事务处理使用transaction()方法,该方方法,该方法的语法格式如下:法的语法格式如下:var tx = idb. transaction (storeNames,mode);HTML5+CSS3 Web前端开发技术前端开发技术11.4 创立对象仓库创立对象仓库对象仓库是数据记录的集合。要在现有数据库中创对象仓库是数据记录的集合。要在现有数据库中创立一个新对象仓库,需
8、要对现有数据库进行版本更立一个新对象仓库,需要对现有数据库进行版本更新。新。要创立一个对象仓库,可以在数据库对象上调用要创立一个对象仓库,可以在数据库对象上调用 createObjectStore() 方法,语法格式如下。方法,语法格式如下。var objectStore=idb. createObjectStore(name,optionalParameters);HTML5+CSS3 Web前端开发技术前端开发技术11.4 创立对象仓库创立对象仓库例如例如11-3创立了名为创立了名为students的对象仓库的对象仓库HTML5+CSS3 Web前端开发技术前端开发技术11.5 创立索引
9、可以使用对象仓库的键来检索对象存储中的记录,也可可以使用对象仓库的键来检索对象存储中的记录,也可以使用索引的字段来检索记录。在以使用索引的字段来检索记录。在IndexedDB数据库中,数据库中,只能对被索引的属性值进行检索。对象仓库可具有一个或多只能对被索引的属性值进行检索。对象仓库可具有一个或多个索引。个索引。创立索引的语法格式如下。创立索引的语法格式如下。var idx=store.createIndex( indexName,indexItem,optionalParameters); 其中,其中,indexName参数值为一个字符串,表示索引名参数值为一个字符串,表示索引名.HTML5
10、+CSS3 Web前端开发技术前端开发技术11.5 创立索引v例如例如11-4创立了创立了3个索引,其中个索引,其中sName是惟一是惟一索引。索引。HTML5+CSS3 Web前端开发技术前端开发技术11.6 保存和删除数据1. 保存数据保存数据 向对象仓库中插入数据,首先需要连接某个向对象仓库中插入数据,首先需要连接某个IndexedDB 数据库,这时,数据库,这时,open()方法中的数据库版本号参数可以省方法中的数据库版本号参数可以省略不写。在连接成功后使用该数据库对象的略不写。在连接成功后使用该数据库对象的transaction方法开启一个读写事务,再使用方法开启一个读写事务,再使用
11、put()方法或方法或add()方法插方法插入数据。入数据。 (1) put()方法或方法或add()方法方法 向对象仓库添加数据可以使用向对象仓库添加数据可以使用put()方法或方法或add()方法,方法,语法格式如下。语法格式如下。var req = store.put(value); HTML5+CSS3 Web前端开发技术前端开发技术11.6 保存和删除数据(2)插入数据的过程插入数据的过程 向对象仓库中插入数据时,首先连接数据库,接着开启事向对象仓库中插入数据时,首先连接数据库,接着开启事务,获取对象仓库,最后插入数据。务,获取对象仓库,最后插入数据。 开启事务后,使用开启事务后,使
12、用transaction()方法开启事务,该方方法开启事务,该方法的参数是事务的作用范围。再使用事务对象的法的参数是事务的作用范围。再使用事务对象的objectStore()方法获取该事务对象的作用范围中的某个方法获取该事务对象的作用范围中的某个对象仓库,代码如下对象仓库,代码如下:var store = tx.objectStore(students); HTML5+CSS3 Web前端开发技术前端开发技术11.6 保存和删除数据v例如例如11-5在在students对象仓库中保存了对象仓库中保存了4条记条记录。录。HTML5+CSS3 Web前端开发技术前端开发技术11.6 保存和删除数据
13、2. 检索数据检索数据(1)使用对象仓库的主使用对象仓库的主键获取记录键获取记录在获取对象仓库成功后,使用对象在获取对象仓库成功后,使用对象仓库的仓库的get()方法从对象仓库中获方法从对象仓库中获取一条数据,代码如下:取一条数据,代码如下:var req = store.get(key); 该请求发出后将被立即异步执行,该请求发出后将被立即异步执行,用户可以通过监听请求对象的用户可以通过监听请求对象的onsuccess事件与请求对象的事件与请求对象的onerror事件并指定事件处理函事件并指定事件处理函数来定义请求被执行成功或失败时数来定义请求被执行成功或失败时所要进行的处理所要进行的处理.
14、req.onsuccess = function (e) /获取数据成功时所执行的处理获取数据成功时所执行的处理 req.onerror = function(e) /获取数据失败时所执行的处理获取数据失败时所执行的处理 HTML5+CSS3 Web前端开发技术前端开发技术11.6 保存和删除数据HTML5+CSS3 Web前端开发技术前端开发技术11.6 保存和删除数据(2)使用索引对象获取记录使用索引对象获取记录除了使用主键获取记录外,如果对象仓库中存在其除了使用主键获取记录外,如果对象仓库中存在其他属性组成的索引,那么可以根据该索引的属性取他属性组成的索引,那么可以根据该索引的属性取得数
15、据。得数据。var tx = idb.transaction(students, readonly); var store = tx.objectStore(students); var idx = store.index(sName); var req = idx.get(Mike); req.onsuccess = function (e) /数据获取成功数据获取成功 req.onerror = function (e) /数据获取失败数据获取失败HTML5+CSS3 Web前端开发技术前端开发技术11.6 保存和删除数据3. 删除数据删除数据使用使用delete()方法可以删除方法可以删
16、除对象仓库中的数据对象仓库中的数据. (keyPath value);HTML5+CSS3 Web前端开发技术前端开发技术11.7 使用游标检索批量数据1. openCursor()方法及其参数方法及其参数 openCursor()方法用于在对象仓库中翻开游方法用于在对象仓库中翻开游标。标。var req=store.openCursor(range,direction); range参数是一个参数是一个IDBKeyRange对象,该对对象,该对象的返回游标的作用范围;象的返回游标的作用范围; direction参数用于指定游标的读取方向,参数参数用于指定游标的读取方向,参数值为一个在值为一个
17、在 IndexedDB API中预定义的常量值中预定义的常量值。HTML5+CSS3 Web前端开发技术前端开发技术11.7 使用游标检索批量数据(1)指定游标范围的方法指定游标范围的方法表表11-1 创立创立IDBKeyRange对象的方法对象的方法方法(范围类型)方法(范围类型)描述描述IDBKeyRange.bound(lower,upper, lowerOpen,upperOpen);返回指定范围内的所有记录,前两个参数是范围的下边界和返回指定范围内的所有记录,前两个参数是范围的下边界和上边界。上边界。两个可选参数两个可选参数lowerOpen 和和 upperOpen,取值为,取值为
18、true或或false,表明下边界或上边界上的记录是否包含在范围内。如果取值为表明下边界或上边界上的记录是否包含在范围内。如果取值为true,不包括边界;如果取值为,不包括边界;如果取值为false,包括边界。默认值为,包括边界。默认值为false。IDBKeyRange.lowerBound (lower,lowerOpen)超过指定的边界值之后的所有记录。可选参数超过指定的边界值之后的所有记录。可选参数lowerOpen,表明下边界的记录是否包含在范围中,解释同上。表明下边界的记录是否包含在范围中,解释同上。IDBKeyRange.upperBound(upper,upperOpen);返
19、回指定的边界值之前的所有记录。可选参数返回指定的边界值之前的所有记录。可选参数upperOpen,表明上边界的记录是否应包含在范围中,解释同上。表明上边界的记录是否应包含在范围中,解释同上。IDBKeyRange.only(value)仅返回与指定值匹配的记录。仅返回与指定值匹配的记录。HTML5+CSS3 Web前端开发技术前端开发技术11.7 使用游标检索批量数据(2)指定游标的顺序指定游标的顺序openCursor()方法的第方法的第2个参数个参数direction用于指明游标用于指明游标的方向,有的方向,有4种取值。种取值。 :顺序循环:顺序循环 :顺序循环且键值不重复:顺序循环且键值
20、不重复 :倒序循环:倒序循环 :倒序循环且键值不重复:倒序循环且键值不重复HTML5+CSS3 Web前端开发技术前端开发技术11.7 使用游标检索批量数据2.数据遍历数据遍历A.遍历对象仓库中的所有数据遍历对象仓库中的所有数据例如例如11-8是遍历是遍历students对象仓库的所有记录,对象仓库的所有记录,结合这个例如,说明遍历对象仓库中记录的步骤。结合这个例如,说明遍历对象仓库中记录的步骤。1连接数据库。连接数据库。 init()方法完成连接数据库操作,并得到一个数方法完成连接数据库操作,并得到一个数据库对象据库对象idb。 单击网页页面中的单击网页页面中的“Travel Data按钮,显示按钮,显示数据的遍历结果。数据的遍历结果。2启动事务,并指定事务的作用
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年度钢构工程钢结构焊接与检验合同协议
- 二零二五年度车牌号码竞拍交易合同4篇
- 2025年牛津译林版选择性必修1历史下册阶段测试试卷含答案
- 2025年度食品存货质押担保业务合同3篇
- 2025年人民版七年级物理下册阶段测试试卷
- 二零二五年度高科技产业财产抵押担保投资合同2篇
- 2025年沪教版九年级生物上册阶段测试试卷
- 2025年外研版第二册生物上册阶段测试试卷
- 2025年粤教沪科版八年级历史上册月考试卷含答案
- 2025年度汽车租赁与导航系统使用合同4篇
- 云南省普通高中学生综合素质评价-基本素质评价表
- 2024年消防产品项目营销策划方案
- 旅游公司发展规划
- 闻道课件播放器
- 03轴流式压气机b特性
- 五星级酒店收入测算f
- 大数据与人工智能ppt
- 人教版八年级下册第一单元英语Unit1 单元设计
- GB/T 9109.5-2017石油和液体石油产品动态计量第5部分:油量计算
- 邀请函模板完整
- 2023年江苏省南京市中考化学试卷2
评论
0/150
提交评论