vue-electron problem solution when using serialport

vue-electron problem solution when using serialport

The error is as follows:

Uncaught TypeError: Cannot read property 'modules' of undefined
at Object.eval (webpack-internal:///./node_modules/bindings/bindings.js:29)
at eval (webpack-internal:///./node_modules/bindings/bindings.js:223)
at Object../node_modules/bindings/bindings.js (chunk-vendors.js:255)
at __webpack_require__ (app.js:849)
at fn (app.js:151)
at eval (webpack-internal:///./node_modules/@serialport/bindings/lib/linux.js:2)
at Object../node_modules/@serialport/bindings/lib/linux.js (chunk-vendors.js:65)
at __webpack_require__ (app.js:849)
at fn (app.js:151)
at Object.eval (webpack-internal:///./node_modules/@serialport/bindings/lib/index.js:14)

To sum up: webpack can't parse binary or something... There is a discussion on github

System: win10  
"dependencies": {
    "core-js": "^3.6.5",
    "electron-prebuilt": "^1.4.13",
    "serialport": "^9.2.1",
    "vue": "^2.6.11"
},
"devDependencies": {
    "@vue/cli-plugin-babel": "~4.5.0",
    "@vue/cli-plugin-eslint": "~4.5.0",
    "@vue/cli-service": "~4.5.0",
    "babel-eslint": "^10.1.0",
    "electron": "^13.0.0",
    "electron-devtools-installer": "^3.1.0",
    "electron-rebuild": "^3.2.3",
    "eslint": "^6.7.2",
    "eslint-plugin-vue": "^6.2.2",
    "vue-cli-plugin-electron-builder": "~2.1.1",
    "vue-template-compiler": "^2.6.11"
},

Solution:

const { IgnorePlugin } = require('webpack')
 
module.exports = {
  pluginOptions: {
    plugins: [
      new IgnorePlugin({
        resourceRegExp: /serialport/
      })
    ],
    electronBuilder: {
      nodeIntegration: true,
      externals: [
        'serialport'
      ]
    }
  }
} 

app.allowRendererProcessReuse = false 

Just re-run

This is the end of this article about solutions to problems when vue-electron uses serialport. For more related content about problems when vue-electron uses serialport, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope you will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Detailed explanation of desktop application using Vue3 and Electron
  • Detailed explanation of client configuration for vue3+electron12+dll development
  • An example of how to build a local player from scratch using Electron+vue
  • Solution to callback in dialog of electron pitfall
  • Solution to electron's remote of undefined problem
  • Detailed graphic explanation of the construction process of Electron project based on Vue

<<:  Detailed explanation of the usage of grep command in Linux

>>:  Is mysql a relational database?

Recommend

Tutorial on installing mysql under centos7

Recently, I plan to deploy a cloud disk on my hom...

About 3 common packages of rem adaptation

Preface I wrote an article about rem adaptation b...

How to change the MySQL database directory location under Linux (CentOS) system

How to change the MySQL database directory locati...

Detailed explanation of Navicat's slow remote connection to MySQL

The final solution is in the last picture If you ...

Vue uses Baidu Maps to realize city positioning

This article shares the specific code of Vue usin...

How to use VIM editor in Linux

As a powerful editor with rich options, Vim is lo...

Detailed explanation of WeChat Mini Program official face verification

The mini program collected user personal informat...

Create an SSL certificate that can be used in nginx and IIS

Table of contents Creating an SSL Certificate 1. ...

Detailed instructions for installing mysql5.7 database under centos7.2

The mysql on the server is installed with version...

A brief discussion on CSS cascading mechanism

Why does CSS have a cascading mechanism? Because ...

How to set process.env.NODE_ENV production environment mode

Before I start, let me emphasize that process.env...

Detailed explanation of nginx reverse proxy webSocket configuration

Recently, I used the webSocket protocol when work...

A brief talk about MySQL pivot tables

I have a product parts table like this: part part...