解决npm run start 和 node.js src/main.js 引用资源文件路径不一致问题

解决npm run start 和 node.js src/main.js 引用资源文件路径不一致问题

问题描述

  • 写了一个node.js连接sqlite3数据库的项目,因为数据库sqlite3.db文件相对于根目录和src/main.js路径不一致,打包时总有一种方法失败

分析原因

  • 数据库sqlite3.db文件是相对控制台运行命令的相对路径
  • npm run start 的相对路径是根目录/,
  • src/main.js 的相对路径是根目录/src目录
  • 即使你在package.json 配置了main.js的相对路径,数据库sqlite3.db相对于控制台的路径会发生改变,所以应该修改为相对于当前文件的路径,当前文件的绝对路径不会发生改变
JSON 复制代码
{
  "main": "./src/main.js",
  "scripts": {
  	"start": "node src/main.js",
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "dependencies": {
    "sqlite3": "^5.1.7"
  }
}

解决方法

  • 将数据库sqlite3.db的路径修改为相对于当前目录下的sqlite3.db路径
JavaScript 复制代码
// 打开/创建数据库
//let db = new sqlite3.Database('nav.db'); 

修改为

JavaScript 复制代码
// 显示当前文件的绝对路径
//console.log(__dirname)
// 解决npm和node运行时,数据库路径不一致问题
const databasePath = path.join(__dirname, '', 'nav.db')
let db = new sqlite3.Database(databasePath)

测试

  • 使用命令行测试结果一致
控制台 复制代码
npm run start

或者

控制台 复制代码
node src/main.js

或者

控制台 复制代码
cd src
node main.js
相关推荐
我叫张小白。37 分钟前
Vue3监视系统全解析
前端·javascript·vue.js·前端框架·vue3
娃哈哈哈哈呀6 小时前
formData 传参 如何传数组
前端·javascript·vue.js
2503_928411568 小时前
11.24 Vue-组件2
前端·javascript·vue.js
g***B7388 小时前
JavaScript在Node.js中的模块系统
开发语言·javascript·node.js
Z***25809 小时前
JavaScript在Node.js中的Deno
开发语言·javascript·node.js
cypking9 小时前
Vue 3 + Vite + Router + Pinia + Element Plus + Monorepo + qiankun 构建企业级中后台前端框架
前端·javascript·vue.js
San30.10 小时前
ES6+ 新特性解析:让 JavaScript 开发更优雅高效
开发语言·javascript·es6
u***276111 小时前
TypeScript 与后端开发Node.js
javascript·typescript·node.js
星空的资源小屋11 小时前
跨平台下载神器ArrowDL,一网打尽所有资源
javascript·笔记·django
Dorcas_FE12 小时前
【tips】动态el-form-item中校验的注意点
前端·javascript·vue.js