报错如下:
node_modules/bindings/bindings.js:121
throw e;
^
Error: Module did not self-register: 'xxxx/node_modules/drivelist/build/Release/drivelist.node'.
at process.func [as dlopen] (electron/js2c/asar.js:140:31)
at Object.Module._extensions..node (internal/modules/cjs/loader.js:1034:18)
at Object.func [as .node] (electron/js2c/asar.js:140:31)
at Module.load (internal/modules/cjs/loader.js:815:32)
at Module._load (internal/modules/cjs/loader.js:727:14)
at Function.Module._load (electron/js2c/asar.js:769:28)
at Module.require (internal/modules/cjs/loader.js:852:19)
at require (internal/modules/cjs/helpers.js:74:18)
at bindings (xxxx/node_modules/bindings/bindings.js:112:48)
at Object.<anonymous> (xxxx/node_modules/drivelist/js/index.js:25:27)
网上最多的解决方法是执行rebuild,或者清空所有自动生成的文件重新执行yarn。但是我的项目还是一直报这个错,并没有解决。
产生这个报错的原因是:nodejs的编译版本和使用的版本不一致,所以在编译的时候并不会报错,但是在运行的时候就会报错!
我的电脑里确实有两个nodejs版本,可以看到我使用的是v18.17.0
但是由于各种原因,我之前是使用的是v20.15.0,并把它设置到了配置里(这里是问题所在),现在使用的是v18.17.0,所以存在了版本不一致问题。
看一下我的配置里的设置,默认是在如下两个文件中
里边之前设置nodedir总是使用v20.15.0,但是我node -v输出的版本是v18.17.0
所以解决办法是:在.npmrc 和 .yarnrc 文件中把关于node的版本相关的配置都注释掉(使用#
进行注释),
然后重新执行install和build,这样就能使用唯一的版本进行编译和运行了。