在chrome(版本 70.0.3538.110)测试正常

编写涉及:css, html, js

在线演示codepen

html代码

<h1>indexedDB</h1>
<h2>在 DevTools 的 Application 中查看数据库信息</h2> <button onclick="addDBData()">添加数据</button>
<div>
<button onclick="getDBData()">获取数据</button>
<input type="text" id="getID" placeholder="请输入ID">
</div>
<div>
<button onclick="delDBData()">删除数据</button>
<input type="text" id="delID" placeholder="请输入ID">
</div>
<div>
<button onclick="updateDBData()">更新数据</button>
<input type="text" id="updateID" placeholder="请输入ID">
</div>
<div id="display"></div>

css代码

button {
margin: 10px 0;
padding: 8px 10px;
border: 0;
color: #fff;
background-color: rgb(7, 196, 230);
}
input{
padding: 8px 5px;
border: rgb(7, 196, 230) solid 1px
}

JavaScript代码

window.indexedDB = window.indexedDB || window.mozIndexedDB || window.webkitIndexedDB || window.msIndexedDB;
if (!window.indexedDB) {
alert('不支持indexDB')
} const DATA_BASE = 'TEST_DB'
let db = {} /**
1. 不存在当前数据库时,即为创建
2. open参数:数据库名称,版本号(整数)
*/
const request = window.indexedDB.open(DATA_BASE, 1) request.onerror = function (e) {
console.error('error', e)
} /**
1. 数据库已存在,打开成功
*/
request.onsuccess = function (event) {
db = event.target.result
console.log('execute onsuccess');
}; /**
1. 当数据库不存在时,创建数据库会触发 onupgradeneeded 事件
2. 当指定的版本号高于当前时会直接触发 onupgradeneeded 事件
3. 唯一可以修改数据库结构的事件
*/
request.onupgradeneeded = function (event) {
/**
1. 保存 IDBDataBase 接口(数据库)
*/
db = event.target.result
console.log('execute onupgradeneeded'); /**
1.使用键生成器,测试时,去除注释即可
*/
// const objectStore = db.createObjectStore('users', { autoIncrement : true })
// objectStore.add({name: '123'});
// objectStore.add('123'); /**
1. 为当前数据库创建对象仓库(表)
2. 这里的keyPath 相当于主键
3. createIndex(indexName, keyPath, {unique | multiEntry | locale})
*/
const objectStore = db.createObjectStore('users', { keyPath: 'id' })
objectStore.createIndex('name', 'name', { unique: false })
objectStore.createIndex('age', 'age', { unique: false }) /**
1. 确保初始化数据的时候,对象仓库已经创建完毕
*/
objectStore.transaction.oncomplete = function(event) {
const transaction = db.transaction(['users'], 'readwrite')
const objStore = transaction.objectStore('users')
objStore.add({
id: 12,
name: `hew-${Math.random()}` ,
age: parseInt( Math.random() * 100, 10)
})
}
} /**
1. 所有数据库操作都基于事务
2. 事务三种模式:readonly,readwrite,versionchange
3. 修改数据库模式或结构——包括新建或删除对象仓库或索引,只能用 versionchange 模式
*/
function addDBData() {
const transaction = db.transaction(['users'], 'readwrite')
const objectStore = transaction.objectStore('users')
const request = objectStore.add({
id: Math.random() * 10,
name: `hew-${Math.random()}` ,
age: parseInt( Math.random() * 100, 10)
}) transaction.oncomplete = function (event) {
console.log('transaction add complete')
} transaction.onerror = function (error) {
console.error('add error', error)
} request.onsuccess = function (event) {
console.log('add complete')
}
} function getDBData() {
const id = parseFloat(document.getElementById('getID').value)
const transaction = db.transaction(['users'], 'readwrite')
const objectStore = transaction.objectStore('users') /**
1. 注意数据类型
*/
const request = objectStore.get(id) request.onsuccess = function (event) {
console.log('get complete', event.target.result)
document.getElementById('display').innerHTML = JSON.stringify(request.result)
} request.onerror = function (err) {
console.error('get error', err)
}
} function updateDBData() {
const id = parseFloat(document.getElementById('updateID').value)
const transaction = db.transaction(['users'], 'readwrite')
const objectStore = transaction.objectStore('users')
const request = objectStore.get(id) request.onsuccess = function (event) {
const d = event.target.result
d.name = 'name name'
const objectStoreUpdate = objectStore.put(d)
objectStoreUpdate.onsuccess = function (e) {
console.log('update success')
} document.getElementById('display').innerHTML = 'update success'
} request.onerror = function (err) {
console.error('get error', err)
} } function delDBData() {
const id = parseFloat(document.getElementById('delID').value)
const request = db.transaction(['users'], 'readwrite').objectStore('users').delete(id) request.onsuccess = function() {
console.log('delete complete', id);
}
}

参考

若有疑问或错误,请留言,谢谢!Github blog issues

indexedDB添加,删除,获取,修改的更多相关文章

  1. JavaScript Dom基础-9-Dom查找方法; 设置DOM元素的样式; innerHTML属性的应用; className属性的应用; DOM元素上添加删除获取属性;

    JavaScript Dom基础 学习目标 1.掌握基本的Dom查找方法 domcument.getElementById() Domcument.getElementBy TagName() 2.掌 ...

  2. linux下添加删除,修改,查看用户和用户组

    一.组操作 1.创建组: groupadd test #增加一个test组 2.修改组 groupmod -n test2 test #将test组的名子改成test2 3.删除组 groupdel ...

  3. mongodb查看操作记录方法以及用户添加删除权限修改密码

    前一阵跑程序时发现一个问题,同事导出了部分数据,但是在merge回原库时竟然和原库的数据对不上,后来找了半天发现是原库数据少了. 找了很多资料发现很多人认为的操作日志和我想的不太一样...找了半条才发 ...

  4. jQuery08源码 (5140 , 6057) DOM操作 : 添加 删除 获取 包装 DOM筛选

    jQuery.fn.extend({ //$('ul').find('li').css('background','red'); //$('ul').find( $('li') ).css('back ...

  5. js+jquery动态设置/添加/删除/获取元素属性的两种方法集锦对照(动态onclick属性设置+动态title设置)

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN" "http://www.w3.org/TR/REC-html140 ...

  6. jquery17 DOM操作 : 添加 删除 获取 包装 DOM筛选

    <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...

  7. jquery16 DOM操作 : 添加 删除 获取 包装 DOM筛选

    <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...

  8. 如何管理和记录 SSIS 各个 Task 的开始执行时间和结束时间以及 Task 中添加|删除|修改的记录数

    开篇语 在这篇日志中 如何在 ETL 项目中统一管理上百个 SSIS 包的日志和包配置框架 我介绍到了包级别的日志管理框架,那么这个主要是针对包这一个层级的 Log 信息,包括包开始执行和结束时间,以 ...

  9. SQL语句的添加、删除、修改多种方法

    SQL语句的添加.删除.修改虽然有如下很多种方法,但在使用过程中还是不够用,不知是否有高手把更多灵活的使用方法贡献出来? 添加.删除.修改使用db.Execute(Sql)命令执行操作╔------- ...

  10. C# 添加、获取及删除PDF附件

    C# 添加.获取及删除PDF附件 前言 附件在PDF文档中很常见,这些附件可以是PDF或其他类型的文件.在PDF中,附件有两种存在方式,一种是普通的文件附件(document-level file a ...

随机推荐

  1. Linux中修改远程地址

    首先跳转到本地用户root,如果不是的话可能没有权限 第一步:安装ssh服务 执行命令:yum install openssh-server (因为我已经安装过了,所以显示的是已安装) 第二步:修改S ...

  2. django基础知识之定义模型:

    定义模型 在模型中定义属性,会生成表中的字段 django根据属性的类型确定以下信息: 当前选择的数据库支持字段的类型 渲染管理表单时使用的默认html控件 在管理站点最低限度的验证 django会为 ...

  3. git简介 http://msysgit.github.io/

    集中式vs分布式 Linus一直痛恨的CVS及SVN都是集中式的版本控制系统,而Git是分布式版本控制系统,集中式和分布式版本控制系统有什么区别呢? 先说集中式版本控制系统,版本库是集中存放在中央服务 ...

  4. Linux命令学习-history命令

    Linux中,history命令的作用是显示历史记录和执行过的命令. 查看历史所有命令执行记录 history 查看最近的13条历史执行命令 history 13 执行历史记录中,序号为123的命令 ...

  5. [开源]OSharpNS 步步为营系列 - 3. 添加业务服务层

    什么是OSharp OSharpNS全称OSharp Framework with .NetStandard2.0,是一个基于.NetStandard2.0开发的一个.NetCore快速开发框架.这个 ...

  6. IIS配置应用时,请求Header或Cookie过长

    可以在注册表中配置IIS MaxFieldLength MaxRequestBytes 注意配置后需重启http服务于iis服务 net stop http net start http iisres ...

  7. Zimg—轻量级图片服务器搭建利器

    在一个互联网应用中,图片扮演着越来越重要的角色.有稳定的可扩展的图片存储服务器就显得尤为的重要,云厂商们提供了便利的图片存储服务,花钱就可以解决了.这里简单介绍一个开源的一个分布式图片存储服务器--z ...

  8. 前端动画 wow.js 效果

    让花里胡哨的特效变简单 wow.js动画class介绍 引入css样式以及js插件 <link rel="stylesheet" type="text/css&qu ...

  9. TigerGraph入门

    测试机器配置 1G内存,1个核,CentOS Linux release 7.4.1708 (Core)的云主机,一块50G HDD的云主机. 1. 安装 下载了目前最新的开发者版本,下载链接:htt ...

  10. springboot启动不设置端口

    非web工程 在服务架构中,有些springboot工程只是简单的作为服务,并不提供web服务 这个时候不需要依赖 <dependency> <groupId>org.spri ...