更具体的介绍:https://zh.javascript.info/indexeddb

认识 Indexed DB

IndexedDB 是一种客户端的数据库(Database),有时候我们可能会存储一些简单的数据到本地(浏览器中),比如 token、用户名、密码、用户信息等,比较少存储大量的数据;那么如果确实有大量的数据需要存储,这个时候可以选择使用 IndexedDB;

IndexedDB 是浏览器的一种底层 API,用于在客户端存储大量的结构化数据。

  • 它是一种事务型数据库系统,是一种基于JavaScript面向对象数据库,有点类似于NoSQL(非关系型数据库);
  • IndexDB 本身就是基于事务的,我们只需要指定数据库模式,打开与数据库的连接,然后检索和更新一系列事务即可。

image.png

连接数据库

第一步:打开indexDB的某一个数据库;

  • 通过indexDB.open(数据库名称, 数据库版本)方法;
  • 如果数据库不存在,那么会创建这个数据;
  • 如果数据库已经存在,那么会打开这个数据库;

第二步:通过监听回调得到数据库连接结果;

  • 数据库的open方法会得到一个IDBOpenDBRequest类型
  • 我们可以通过下面的三个回调来确定结果:
    • onerror:当数据库连接失败时;
    • onsuccess:当数据库连接成功时回调;
    • onupgradeneeded:当数据库的version发生变化并且高于之前版本时回调;
      • 通常我们在这里会创建具体的存储对象:db.createObjectStore(存储对象名称, { keypath: 存储的主键 })
  • 我们可以通过onsuccess回调的event获取到db对象:event.target.result

    数据库操作

    我们对数据库的操作要通过事务对象来完成:

  • 第一步:通过db获取对应存储的事务 db.transaction(存储名称, 可写操作);

  • 第二步:通过事务获取对应的存储对象 transaction.objectStore(存储名称);

接下来我们就可以进行增删改查操作了:

  • 新增数据 store.add
  • 查询数据
    • 方式一:store.get(key)
    • 方式二:通过 store.openCursor 拿到游标对象
      • 在request.onsuccess中获取cursor:event.target.result
      • 获取对应的key:cursor.key;
      • 获取对应的value:cursor.value;
      • 可以通过cursor.continue来继续执行;
  • 修改数据 cursor.update(value)
  • 删除数据 cursor.delete() ```javascript // 打开数据(和数据库建立连接) const dbRequest = indexedDB.open(‘why’, 3) dbRequest.onerror = function (err) { console.log(‘打开数据库失败~’) } let db = null dbRequest.onsuccess = function (event) { db = event.target.result } // 第一次打开/或者版本发生升级 dbRequest.onupgradeneeded = function (event) { const db = event.target.result

    console.log(db)

    // 创建一些存储对象 db.createObjectStore(‘users’, { keyPath: ‘id’ }) }

class User { constructor(id, name, age) { this.id = id this.name = name this.age = age } }

const users = [new User(100, ‘why’, 18), new User(101, ‘kobe’, 40), new User(102, ‘james’, 30)]

// 获取btns, 监听点击 const btns = document.querySelectorAll(‘button’) for (let i = 0; i < btns.length; i++) { btns[i].onclick = function () { const transaction = db.transaction(‘users’, ‘readwrite’) console.log(transaction) const store = transaction.objectStore(‘users’)

  1. switch (i) {
  2. case 0:
  3. console.log('点击了新增')
  4. for (const user of users) {
  5. const request = store.add(user)
  6. request.onsuccess = function () {
  7. console.log(`${user.name}插入成功`)
  8. }
  9. }
  10. transaction.oncomplete = function () {
  11. console.log('添加操作全部完成')
  12. }
  13. break
  14. case 1:
  15. console.log('点击了查询')
  16. // 1.查询方式一(知道主键, 根据主键查询)
  17. // const request = store.get(102)
  18. // request.onsuccess = function(event) {
  19. // console.log(event.target.result)
  20. // }
  21. // 2.查询方式二:
  22. const request = store.openCursor()
  23. request.onsuccess = function (event) {
  24. const cursor = event.target.result
  25. if (cursor) {
  26. if (cursor.key === 101) {
  27. console.log(cursor.key, cursor.value)
  28. } else {
  29. cursor.continue()
  30. }
  31. } else {
  32. console.log('查询完成')
  33. }
  34. }
  35. break
  36. case 2:
  37. console.log('点击了删除')
  38. const deleteRequest = store.openCursor()
  39. deleteRequest.onsuccess = function (event) {
  40. const cursor = event.target.result
  41. if (cursor) {
  42. if (cursor.key === 101) {
  43. cursor.delete()
  44. } else {
  45. cursor.continue()
  46. }
  47. } else {
  48. console.log('查询完成')
  49. }
  50. }
  51. break
  52. case 3:
  53. console.log('点击了修改')
  54. const updateRequest = store.openCursor()
  55. updateRequest.onsuccess = function (event) {
  56. const cursor = event.target.result
  57. if (cursor) {
  58. if (cursor.key === 101) {
  59. const value = cursor.value
  60. value.name = 'curry'
  61. cursor.update(value)
  62. } else {
  63. cursor.continue()
  64. }
  65. } else {
  66. console.log('查询完成')
  67. }
  68. }
  69. break
  70. }

} }

```