Я написал модуль c ++, используя n-api , скомпилировал его с помощью cmake- js и теперь хочу использовать его в моем приложении electron-vue
. Если я использую модуль в проекте без electron-vue
, он работает. Но когда я пытаюсь использовать его в своем приложении electron-vue
, я всегда получаю эту ошибку:
App threw an error during load
TypeError: Cannot read property 'indexOf' of undefined
at Function.getFileName (D:\temp\test2\node_modules\bindings\bindings.js:178:16)
at bindings (D:\temp\test2\node_modules\bindings\bindings.js:82:48)
at eval (webpack:///./src/main/index.js?:28:67)
at Module../src/main/index.js (D:\temp\test2\dist\electron\main.js:3822:1)
at __webpack_require__ (D:\temp\test2\dist\electron\main.js:21:30)
at eval (webpack:///./src/main/index.dev.js?:11:1)
at Object../src/main/index.dev.js (D:\temp\test2\dist\electron\main.js:3810:1)
at __webpack_require__ (D:\temp\test2\dist\electron\main.js:21:30)
at eval (webpack:///multi_./src/main/index.dev.js_./src/main/index.js?:1:1)
at Object.0 (D:\temp\test2\dist\electron\main.js:3880:1)
Я использую привязки примерно так:
const colorBalance = require('bindings')('colorBalance');
Я пытался определить мой модуль как внешний в соответствии с этим , но это не решило проблему:
// vue.config.js
module.exports = {
pluginOptions: {
electronBuilder: {
externals: ['NameOfMyModule']
}
}
}