解决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
相关推荐
此乃大忽悠41 分钟前
XSS(ctfshow)
javascript·web安全·xss·ctfshow
江城开朗的豌豆2 小时前
Vuex数据突然消失?六招教你轻松找回来!
前端·javascript·vue.js
好奇心笔记2 小时前
ai写代码随机拉大的,所以我准备给AI出一个设计规范
前端·javascript
江城开朗的豌豆2 小时前
Vue状态管理进阶:数据到底是怎么"跑"的?
前端·javascript·vue.js
我想说一句2 小时前
React待办事项开发记:Hook魔法与组件间的悄悄话
前端·javascript·前端框架
真夜2 小时前
CommonJS与ESM
前端·javascript
G等你下课2 小时前
从点击到执行:如何优雅地控制高频事件触发频率
前端·javascript·面试
Jackson_Mseven2 小时前
面试官:说说 startTransition 和 useDeferredValue?我:我用它一行代码救了首页!
前端·javascript·面试
架构个驾驾2 小时前
从0到1搭建Vue3+Vant移动端项目(一)
前端·javascript·vue.js
然我2 小时前
React 中 useEffect 到底怎么用才不会踩坑?全流程详解 + 实例讲透副作用
前端·javascript·react.js