indexedDB添加,删除,获取,修改
在chrome(版本 70.0.3538.110)测试正常
编写涉及:css, html, js
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添加,删除,获取,修改的更多相关文章
- JavaScript Dom基础-9-Dom查找方法; 设置DOM元素的样式; innerHTML属性的应用; className属性的应用; DOM元素上添加删除获取属性;
JavaScript Dom基础 学习目标 1.掌握基本的Dom查找方法 domcument.getElementById() Domcument.getElementBy TagName() 2.掌 ...
- linux下添加删除,修改,查看用户和用户组
一.组操作 1.创建组: groupadd test #增加一个test组 2.修改组 groupmod -n test2 test #将test组的名子改成test2 3.删除组 groupdel ...
- mongodb查看操作记录方法以及用户添加删除权限修改密码
前一阵跑程序时发现一个问题,同事导出了部分数据,但是在merge回原库时竟然和原库的数据对不上,后来找了半天发现是原库数据少了. 找了很多资料发现很多人认为的操作日志和我想的不太一样...找了半条才发 ...
- jQuery08源码 (5140 , 6057) DOM操作 : 添加 删除 获取 包装 DOM筛选
jQuery.fn.extend({ //$('ul').find('li').css('background','red'); //$('ul').find( $('li') ).css('back ...
- js+jquery动态设置/添加/删除/获取元素属性的两种方法集锦对照(动态onclick属性设置+动态title设置)
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN" "http://www.w3.org/TR/REC-html140 ...
- jquery17 DOM操作 : 添加 删除 获取 包装 DOM筛选
<!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...
- jquery16 DOM操作 : 添加 删除 获取 包装 DOM筛选
<!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...
- 如何管理和记录 SSIS 各个 Task 的开始执行时间和结束时间以及 Task 中添加|删除|修改的记录数
开篇语 在这篇日志中 如何在 ETL 项目中统一管理上百个 SSIS 包的日志和包配置框架 我介绍到了包级别的日志管理框架,那么这个主要是针对包这一个层级的 Log 信息,包括包开始执行和结束时间,以 ...
- SQL语句的添加、删除、修改多种方法
SQL语句的添加.删除.修改虽然有如下很多种方法,但在使用过程中还是不够用,不知是否有高手把更多灵活的使用方法贡献出来? 添加.删除.修改使用db.Execute(Sql)命令执行操作╔------- ...
- C# 添加、获取及删除PDF附件
C# 添加.获取及删除PDF附件 前言 附件在PDF文档中很常见,这些附件可以是PDF或其他类型的文件.在PDF中,附件有两种存在方式,一种是普通的文件附件(document-level file a ...
随机推荐
- Ural 2072:Kirill the Gardener 3(DP)
http://acm.timus.ru/problem.aspx?space=1&num=2072 题意:有n朵花,每朵花有一个饥渴值.现在浇花,优先浇饥渴值小的(即从小到大浇),浇花需要耗费 ...
- [常用命令]Git命令
取得Git仓库 初始化一个版本仓库 git init Clone远程版本库 git clone https://github.com/yhj167/yhj167.github.io.git 添加远程版 ...
- Visual Studio中Es6的开发环境搭建
1.打开终端,输入初始化代码.输入代码之后会在目录中出现package.json,可以在红色下划线上写上作者名和描述(不写也可以) npm init -y 2.安装Babel转换器 npm in ...
- 5分钟完成mysql离线安装
1. 场景描述 mysql离线安装并不复杂,就是经常会出现漏东西,有时候的搞半天,总结下,快速离线安装mysql,直接把下面的命令敲一遍就好,5-10分钟就能安装好. 2. 解决方案 安装的mysql ...
- secureCRT背景颜色
secureCRT是我们常用的linux远程登录软件,某些情况下我们安装的secureCRT工具可能默认背景颜色为白色,使用时很容易造成眼睛的疲劳,网上有些教程也只是修改当前登录窗口背景颜色,新的连接 ...
- Oracle使用MyBatis中RowBounds实现分页查询
Oracle中分页查询因为存在伪列rownum,sql语句写起来较为复杂,现在介绍一种通过使用MyBatis中的RowBounds进行分页查询,非常方便. 使用MyBatis中的RowBounds进行 ...
- VMware上安装虚拟机-教程
xl_echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!! - ...
- 说说WPF的依赖属性
首先,我们先来大概了解一下依赖属性 什么是依赖属性:依赖属性自己没有值,通过依赖别人(如Binding)来获得值. 依赖属性为什么会出现:控件常用字段有限,包装太多属性会占用过高内存,造成浪费.所以用 ...
- CentOS 7.3 安装python3
1.排查 CentOS 7.3 默认安装的是python2,使用命令 python -V 可以看到 python 的版本 Python 2.7.5 然后使用命令 which python 查看一下Py ...
- spring boot入门篇
Spring Boot[快速入门] Spring Boot 概述 Build Anything with Spring Boot:Spring Boot is the starting point ...