electron-vite初遇

electron-vite 是一个新型 Electron 开发构建工具,旨在为 Electron 提供更快、更精简的开发体验。这次主要是使用react-ts模板,实战过程中也遇到些问题,记录一下当时的解决方案;

项目中依赖
typescript 复制代码
{
  "name": "my-app",
  "version": "1.0.0",
  "description": "An Electron application with React and TypeScript",
  "main": "./out/main/index.js",
  "author": "example.com",
  "homepage": "https://www.electronjs.org",
  "scripts": {
    "format": "prettier --write .",
    "lint": "eslint . --ext .js,.jsx,.cjs,.mjs,.ts,.tsx,.cts,.mts --fix",
    "typecheck:node": "tsc --noEmit -p tsconfig.node.json --composite false",
    "typecheck:web": "tsc --noEmit -p tsconfig.web.json --composite false",
    "typecheck": "npm run typecheck:node && npm run typecheck:web",
    "start": "electron-vite preview",
    "serve": "electron-vite dev",
    "build": "npm run typecheck && electron-vite build",
    "postinstall": "electron-builder install-app-deps",
    "build:win": "npm run build && electron-builder --win --config",
    "build:mac": "electron-vite build && electron-builder --mac --config",
    "build:linux": "electron-vite build && electron-builder --linux --config"
  },
  "dependencies": {
    "@electron-toolkit/preload": "^2.0.0",
    "@electron-toolkit/utils": "^1.0.2",
    "electron-updater": "^5.3.0"
  },
  "devDependencies": {
    "@electron-toolkit/tsconfig": "^1.0.1",
    "@electron/notarize": "^1.2.3",
    "@reduxjs/toolkit": "^1.9.5",
    "@types/node": "^18.16.19",
    "@types/react": "^18.2.14",
    "@types/react-dom": "^18.2.6",
    "@typescript-eslint/eslint-plugin": "^5.62.0",
    "@typescript-eslint/parser": "^5.62.0",
    "@vitejs/plugin-react": "^4.0.3",
    "antd": "^5.7.3",
    "electron": "^24.6.2",
    "electron-builder": "^23.6.0",
    "electron-vite": "^1.0.25",
    "eslint": "^8.44.0",
    "eslint-config-prettier": "^8.8.0",
    "eslint-plugin-prettier": "^4.2.1",
    "eslint-plugin-react": "^7.32.2",
    "less": "^4.1.3",
    "less-loader": "^11.1.3",
    "moment": "^2.29.4",
    "prettier": "^2.8.8",
    "react": "^18.2.0",
    "react-activation": "^0.12.4",
    "react-dom": "^18.2.0",
    "react-redux": "^8.1.2",
    "react-router-dom": "^6.14.2",
    "redux-persist": "^6.0.0",
    "typescript": "^5.1.6",
    "vite": "^4.4.2"
  }
}
路径别名
typescript 复制代码
// tsconfig.web.json 文件
"paths": {
  "@renderer/*": [
    "src/renderer/src/*"
  ],
  "@/*": [
    "src/renderer/src/*"
  ]
}
// electron.vite.config.ts 文件
resolve: {
  alias: {
    '@renderer': resolve('src/renderer/src'),
    '@': resolve('src/renderer/src')
  }
},
配置less
typescript 复制代码
// 下载less/less-loader
npm i less -D
npm i less-loader -D
// electron.vite.config.ts 文件
renderer: {
    css: {
      preprocessorOptions: {
        less: {
          additionalData: `@import '/src/assets/style/global.less';`,
          javascriptEnabled: true
        }
      }
    },
}
报错: xxxx is declared but its value is never read
typescript 复制代码
/* 方案1 */
// @ts-ignore
const unusedVar: string = "Hello";
/* 方案2[不建议,改完就变成全局,就失去检测的意义] tsconfig.json  */
{ 
    "compilerOptions": { 
        "noUnusedLocals": false,
        "noUnusedParameters": false
    }
}
报错: Content Security Policy
html 复制代码
/* 注销掉meta 标签
`default-src 'self'`:设置默认的资源加载策略,只允许从同源(当前网站)加载资源。  
`script-src 'self'`:设置脚本加载的策略,只允许从同源加载脚本。  
`style-src 'self' 'unsafe-inline'`:设置样式加载的策略,只允许从同源加载样式,同时允许内联样式。
*/

 <meta
      http-equiv="Content-Security-Policy"
      content="default-src 'self'; script-src 'self'; style-src 'self' 'unsafe-inline'"
/>
react多窗口配置
typescript 复制代码
// main.js
 meetingWindow.loadURL(`file://${join(__dirname, '../renderer/index.html')}#/meetingPage`)
相关推荐
We་ct3 分钟前
LeetCode 1. 两数之和:两种高效解法(双指针 + Map)
前端·算法·leetcode·typescript·哈希算法
LYFlied8 分钟前
边缘智能:下一代前端体验的技术基石
前端·人工智能·ai·大模型
1024小神10 分钟前
用css的clip-path裁剪不规则形状的图片展示
前端·css
铅笔侠_小龙虾15 分钟前
Flutter 组件层级关系
前端·flutter·servlet
梵得儿SHI17 分钟前
Vue 高级特性:渲染函数与 JSX 精讲(h 函数语法、JSX 在 Vue 中的应用)
前端·javascript·vue.js·jsx·模板语法·渲染函数·底层视图生成机制
GGGG寄了19 分钟前
CSS——文字控制属性
前端·javascript·css·html
菜鸟茜24 分钟前
ES6核心知识解析01:什么是ES6以及为什么需要ES6
前端·javascript·es6
David凉宸26 分钟前
Vue 3 项目的性能优化策略:从原理到实践(页面展示)
javascript·vue.js·性能优化
C澒30 分钟前
FE BLL 架构:前端复杂业务的逻辑治理方案
前端·架构·前端框架·状态模式
摘星编程31 分钟前
在OpenHarmony上用React Native:ImageGIF动图播放
javascript·react native·react.js