IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 在three.js中如何使用indexedDB本地缓存模型 -> 正文阅读

[JavaScript知识库]在three.js中如何使用indexedDB本地缓存模型

近期在做three.js相关优化,想实现本地缓存模型功能,缩短模型加载时间。
在网上搜了相关资料,没有找到我想用的,终于研究明白了,下面讲下实现过程,如果有优化建议可以提出来,共同进步!

1. 创建indexedDB数据库

在浏览器中创建表结构,表可以在 应用 =》存储 =》indexedDB 中查看
在这里插入图片描述

//用于存储数据库
var db; 

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

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

request.onsuccess = function (event) {
    db = request.result;
    //db = event.target.result; 也能拿到
    console.log("数据库打开成功");
};

//定义表结构
request.onupgradeneeded = function (event) {
    //@ts-ignore
    db = event.target.result;

    var objectStore;
    if (!db.objectStoreNames.contains("book")) {
        objectStore = db.createObjectStore("book", {
            keyPath: "id",
        });

        // 定义存储对象的数据项
        objectStore.createIndex("id", "id", {
            unique: true,
        });
        objectStore.createIndex("name", "name");
        objectStore.createIndex("model", "model");
    }
    console.log("数据库升级成功");
};

//向表中添加数据
function add(book) {

    var request1 = db
        .transaction(["book"], "readwrite") //新建事务,readwrite, readonly(默认), versionchange
        .objectStore("book") //拿到IDBObjectStore 对象
        .add({
            // 插入记录
            id: book.id,
            name: book.name,
            model: book.model,
        });
    request1.onsuccess = function (event) {
        console.log("数据写入成功");
    };
    request1.onerror = function (event) {
        console.log("数据写入失败");
    };
    request1.onabort = function (event) {
        console.log("事务回滚");
    };
}

2. 请求模型文件,并存到indexedDB中

这里我用的ajax

var ajax = new XMLHttpRequest();
ajax.open("get", "/static/three/xi.gltf");
ajax.send();
ajax.onreadystatechange = function () {
    if (ajax.readyState == 4 && ajax.status == 200) {
    	//一定要处理成二进制
        let blob = new Blob([ajax.responseText]);
        
        //向数据库中添加请求回来的模型
        add({ id: 80, name: "xi", model: blob });
    }
};

3.使用three.js加载模型***

从数据库中读取模型文件

var transaction = db.transaction("book", "readwrite");
var store = transaction.objectStore("book");

var dataRequest = store.index("id").get(80);

dataRequest.onsuccess = function (e) {
    console.log(e.target.result.model);
   
   //创建blob对象路径。?
	var url2 = URL.createObjectURL(e.target.result.model);
    console.log(url2);

    this.GLTFLoader = new GLTFLoader();
    this.GLTFLoader.setDRACOLoader(this.DRACOLoader);

	//将新生成的路径传进去
    this.GLTFLoader.load(url2, (gltf) => {
        console.log(gltf);

        resolve(gltf.scene);
    });
};

4.收获成功的喜悦

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-22 20:27:56  更:2022-03-22 20:30:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:53:42-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码