vue3+vite+SQL.js如何讀取db3文件數(shù)據(jù)
vue3+vite+SQL.js讀取db3文件數(shù)據(jù)
最近遇到一個需求是讀取本地SQLite文件,還是花費了點時間才實現(xiàn),沒怎么看到vite方面寫這個的文章,現(xiàn)在分享出來完整流程。
Tips:解決了打包后wasm文件404問題,在后續(xù)
1.pnpm下載SQL.js(什么都可以下)
pnpm add SQL.js
2.【重點】如果你執(zhí)行wasm文件時報錯404,請執(zhí)行:
pnpm add --save-dev @rollup/plugin-wasm
在vite.config,js中寫入:
...
build: {
rollupOptions: {
plugins: [
// 在這里添加 wasm 插件
wasm({
include: /\.wasm$/i // 這里可能需要調整為你的文件路徑和名稱
})
],
}
}
...
3.在使用的頁面中,你需要引入了,但是我在使用setup語法糖寫法時候報錯,因為執(zhí)行順序的問題,這里有兩種解決辦法;
第一種:不使用語法糖,使用setup()形式;
第二種:使用語法糖,結合onMounted,nextTick解決,以下:
import { onMounted, nextTick, ref } from "vue";
import initSqlJs from "sql.js";
const databaseContent = ref(null);
let SQL, db;
onMounted(async (nextTick) => {
SQL = await initSqlJs({
locateFile: (file) => `/node_modules/sql.js/dist/${file}`
});
db = new SQL.Database();
});
4.添加選擇文件控件,選擇.db3文件,觸發(fā)onFileChange 方法
<input type="file" @change="onFileChange" />
<div>
<ul>
<li v-for="(item, index) in databaseContent" :key="index">
{{ item }}
</li>
</ul>
</div>
const onFileChange = (event) => {
const fileInput = event.target;
const file = fileInput.files[0];
if (file) {
const reader = new FileReader();
reader.onload = () => {
const Uints = new Uint8Array(reader.result);
db = new SQL.Database(Uints);
const result = db.exec("SELECT PhotoFile FROM Photo");
if (result && result.length) {
let table = result[0].values.flat().map((str) => {
let newRow = str.replace(".\\", "");
let newOvrRow = newRow + ".ovr";
return [newRow, newOvrRow];
});
databaseContent.value = table.flat();
}
};
reader.readAsArrayBuffer(file);
}
};
主要是這幾句:
const Uints = new Uint8Array(reader.result);
db = new SQL.Database(Uints);
const result = db.exec("SELECT PhotoFile FROM Photo");
...
reader.readAsArrayBuffer(file);
這是db3數(shù)據(jù)庫的結構:

我取其中的PhotoFile值(.ovr不用看,我自己加的):

以上的操作在vue打包后再運行會報錯
因為wasm文件沒有被打包進去,經過排查,主要是sql-wasm.wasm這個文件
1.將該文件復制出來,放在public下,我的路徑是public-vender-sql-wasm.wasm

2.import引入該文件
import sqlWasm from "/vender/sql-wasm.wasm";
onMounted(async (nextTick) => {
SQL = await initSqlJs({
locateFile: (file) => sqlWasm
});
});
3.此時依舊會報錯,需修改vite.config.js配置
添加
assetsInclude: ["**/*.wasm"] publicDir: "public", publicPath: "./", base: "/", // hash模式 ./ 歷史模式 /
總結
完美解決!
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Vue中使用?Aplayer?和?Metingjs?添加音樂插件的方式
這篇文章主要介紹了Vue中使用?Aplayer?和?Metingjs?添加音樂插件,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08

