websql 和 indexedDB本地存储

websq

 // 创建|打开
 var db = openDatabase("person", 1, "test", 0); // '数据库名 版本号 描述 存储容量限制'
 // 创建表
 db.transaction((tx) => {
   tx.executeSql("create table if not exists student (id unique,name)");
 });
 // 新增数据
 db.transaction((tx) => {
   tx.executeSql("insert into student (id,name) values (?,?)", [1, "张三"]);
   tx.executeSql("insert into student (id,name) values (?,?)", [2, "李四"]);
 });

 // 查找数据
 db.transaction((tx) => {
   tx.executeSql("select * from student", [], (tx, res) => {
     const rows = res.rows;
     Object.values(rows).forEach((item) => {
       console.log(item);
       // {id: 1, name: '张三'}
       // {id: 2, name: '李四'}
     });
   });
 });
 // updata delete

indexedDB

IndexedDB 就是浏览器提供的本地数据库,它可以被网页脚本创建和操作。IndexedDB 允许储存大量数据,提供查找接口,还能建立索引。

// 打开数据库
  var request = window.indexedDB.open("db", 1);

  var db;
  request.onsuccess = function (event) {
    db = request.result;
    console.log("数据库打开成功");
    get();
  };

  request.onerror = function (event) {
    console.log("数据库打开报错");
  };

  // 新建对象仓库(即新建表)
  request.onupgradeneeded = function (event) {
    db = event.target.result;
    var objectStore;
    if (!db.objectStoreNames.contains("person")) {
      objectStore = db.createObjectStore("person", { keyPath: "id" });
    }
    console.log("person created");
  };

  // 新增数据 db是异步执行的 注意先后顺序
  function add() {
    const req = db
      .transaction(["person"], "readwrite")
      .objectStore("person")
      .add({ id: 3, name: "王五", age: 24, email: "zhangsan@example.com" });

    req.onsuccess = function (event) {
      console.log("数据写入成功");
    };
    req.onerror = function (event) {
      console.log("数据写入失败");
    };
  }

  // 修改
  function updata() {
    db.transaction(["person"], "readwrite")
      .objectStore("person")
      .put({ id: 1, name: "张三", age: 24, email: "zhangsan@example.com" });
  }

  // 删除
  function deleted() {
    db.transaction(["person"], "readwrite").objectStore("person").delete(1);
  }

  // 查找
  function get() {
    const res = db
      .transaction(["person"], "readwrite")
      .objectStore("person")
      .get(1);

    res.onsuccess = function (e) {
      console.log(res.result);
    };
  }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值