mirror of
https://github.com/electron-vite/electron-vite-vue
synced 2025-01-19 11:56:36 +08:00
chore: 升级 vite@2.0
This commit is contained in:
parent
0ea62ef46a
commit
33114d814d
22
package.json
22
package.json
@ -9,9 +9,9 @@
|
|||||||
"dev:all": "concurrently -n=vue,ele -c=green,blue \"npm run dev:vue\" \"npm run dev:ele\"",
|
"dev:all": "concurrently -n=vue,ele -c=green,blue \"npm run dev:vue\" \"npm run dev:ele\"",
|
||||||
"dev:vue": "vite",
|
"dev:vue": "vite",
|
||||||
"dev:ele": "node -r ts-node/register script/build --env=development --watch",
|
"dev:ele": "node -r ts-node/register script/build --env=development --watch",
|
||||||
"build:vue": "vite build",
|
"build:vue": "vuedx-typecheck . && vite build",
|
||||||
"build:ele": "node -r ts-node/register script/build --env=production",
|
"build:ele": "node -r ts-node/register script/build --env=production",
|
||||||
"build": "rm -rf dist && npm run build:vue && npm run build:ele && electron-builder"
|
"build": "rimraf dist && npm run build:vue && npm run build:ele && electron-builder"
|
||||||
},
|
},
|
||||||
"build": {
|
"build": {
|
||||||
"appId": "308487730@qq.com",
|
"appId": "308487730@qq.com",
|
||||||
@ -44,7 +44,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"vue": "^3.0.0"
|
"vue": "^3.0.5"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@rollup/plugin-alias": "^3.1.1",
|
"@rollup/plugin-alias": "^3.1.1",
|
||||||
@ -53,21 +53,23 @@
|
|||||||
"@rollup/plugin-node-resolve": "^9.0.0",
|
"@rollup/plugin-node-resolve": "^9.0.0",
|
||||||
"@types/minimist": "^1.2.1",
|
"@types/minimist": "^1.2.1",
|
||||||
"@types/wait-on": "^5.2.0",
|
"@types/wait-on": "^5.2.0",
|
||||||
"@vue/compiler-sfc": "^3.0.0",
|
"@vitejs/plugin-vue": "^1.1.4",
|
||||||
|
"@vue/compiler-sfc": "^3.0.5",
|
||||||
|
"@vuedx/typecheck": "^0.6.0",
|
||||||
|
"@vuedx/typescript-plugin-vue": "^0.6.0",
|
||||||
"chalk": "^4.1.0",
|
"chalk": "^4.1.0",
|
||||||
"concurrently": "^5.3.0",
|
"concurrently": "^5.3.0",
|
||||||
"electron": "9.1.0",
|
"electron": "11.2.3",
|
||||||
"electron-builder": "^22.8.0",
|
"electron-builder": "^22.8.0",
|
||||||
"electron-is-dev": "^1.2.0",
|
"electron-store": "^7.0.2",
|
||||||
"electron-store": "^6.0.0",
|
|
||||||
"minimist": "^1.2.5",
|
"minimist": "^1.2.5",
|
||||||
"ora": "^5.0.0",
|
"ora": "^5.0.0",
|
||||||
|
"rimraf": "^3.0.2",
|
||||||
"rollup-plugin-copy": "^3.3.0",
|
"rollup-plugin-copy": "^3.3.0",
|
||||||
"rollup-plugin-esbuild": "^2.4.2",
|
"rollup-plugin-esbuild": "^2.4.2",
|
||||||
"ts-node": "^9.1.1",
|
"ts-node": "^9.1.1",
|
||||||
"typescript": "^4.0.3",
|
"typescript": "^4.1.3",
|
||||||
"vite": "^1.0.0-rc.4",
|
"vite": "^2.0.0"
|
||||||
"wait-on": "^5.2.0"
|
|
||||||
},
|
},
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"vite",
|
"vite",
|
||||||
|
@ -7,9 +7,9 @@ import { watch, rollup, OutputOptions } from 'rollup'
|
|||||||
import minimist from 'minimist'
|
import minimist from 'minimist'
|
||||||
import chalk from 'chalk'
|
import chalk from 'chalk'
|
||||||
import ora from 'ora'
|
import ora from 'ora'
|
||||||
import waitOn from 'wait-on'
|
|
||||||
import electron from 'electron'
|
import electron from 'electron'
|
||||||
import dotenv from 'dotenv'
|
import dotenv from 'dotenv'
|
||||||
|
import { waitOn } from './utils'
|
||||||
import options from './rollup.config'
|
import options from './rollup.config'
|
||||||
import { main } from '../package.json'
|
import { main } from '../package.json'
|
||||||
|
|
||||||
@ -21,16 +21,7 @@ const TAG = '[script/build.ts]'
|
|||||||
const spinner = ora(`${TAG} Electron build...`)
|
const spinner = ora(`${TAG} Electron build...`)
|
||||||
|
|
||||||
if (argv.watch) {
|
if (argv.watch) {
|
||||||
waitOn({
|
waitOn({ port: process.env.PORT as string }).then(msg => {
|
||||||
resources: [`http://localhost:${process.env.PORT}`],
|
|
||||||
log: false,
|
|
||||||
}, err => {
|
|
||||||
if (err) {
|
|
||||||
console.log(err)
|
|
||||||
process.exit(1)
|
|
||||||
}
|
|
||||||
|
|
||||||
// once here, all resources are available
|
|
||||||
const watcher = watch(opt)
|
const watcher = watch(opt)
|
||||||
let child: ChildProcess
|
let child: ChildProcess
|
||||||
watcher.on('change', filename => {
|
watcher.on('change', filename => {
|
||||||
|
18
script/utils.ts
Normal file
18
script/utils.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { get } from 'http'
|
||||||
|
|
||||||
|
/** 轮询监听 vite 启动 */
|
||||||
|
export function waitOn(arg0: { port: string | number; interval?: number; }) {
|
||||||
|
return new Promise(resolve => {
|
||||||
|
const { port, interval = 149 } = arg0
|
||||||
|
let counter = 0
|
||||||
|
const timer: NodeJS.Timer = setInterval(() => {
|
||||||
|
get(`http://localhost:${port}`, res => {
|
||||||
|
clearInterval(timer)
|
||||||
|
console.log('[waitOn]', res.statusCode, res.statusMessage)
|
||||||
|
resolve(res.statusCode)
|
||||||
|
}).on('error', err => {
|
||||||
|
console.log('[waitOn]', `counter:${counter++}`)
|
||||||
|
})
|
||||||
|
}, interval)
|
||||||
|
})
|
||||||
|
}
|
@ -3,7 +3,6 @@
|
|||||||
*/
|
*/
|
||||||
import { join } from 'path'
|
import { join } from 'path'
|
||||||
import { app, BrowserWindow } from 'electron'
|
import { app, BrowserWindow } from 'electron'
|
||||||
import is_dev from 'electron-is-dev'
|
|
||||||
import dotenv from 'dotenv'
|
import dotenv from 'dotenv'
|
||||||
|
|
||||||
dotenv.config({ path: join(__dirname, '../../.env') })
|
dotenv.config({ path: join(__dirname, '../../.env') })
|
||||||
@ -21,9 +20,9 @@ function createWin() {
|
|||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
const URL = is_dev
|
const URL = app.isPackaged
|
||||||
? `http://localhost:${process.env.PORT}` // vite 启动的服务器地址
|
? `file://${join(__dirname, '../render/index.html')}` // vite 构建后的静态文件地址
|
||||||
: `file://${join(__dirname, '../render/index.html')}` // vite 构建后的静态文件地址
|
: `http://localhost:${process.env.PORT}` // vite 启动的服务器地址
|
||||||
|
|
||||||
win?.loadURL(URL)
|
win?.loadURL(URL)
|
||||||
}
|
}
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<img style="height:200px;" src="./assets/electron.png" alt="Electron logo">
|
<img style="height:200px;" src="./assets/electron.png" alt="Electron logo">
|
||||||
<img alt="Vue logo" src="./assets/logo.png" />
|
<img alt="Vue logo" src="./assets/logo.png" />
|
||||||
</div>
|
</div>
|
||||||
<HelloWorld msg="Hello Electron 9.0 + Vue 3.0 + Vite" />
|
<HelloWorld msg="Electron@11、Vue@3、Vite@2" />
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
@ -1,19 +1,89 @@
|
|||||||
<template>
|
<template>
|
||||||
<h1>{{ msg }}</h1>
|
<h1>{{ msg }}</h1>
|
||||||
|
|
||||||
|
<label>
|
||||||
|
<input type="checkbox" v-model="useScriptSetup" /> Use
|
||||||
|
<code><script setup></code>
|
||||||
|
</label>
|
||||||
|
<label>
|
||||||
|
<input type="checkbox" v-model="useTsPlugin" /> Provide types for
|
||||||
|
<code>*.vue</code> imports
|
||||||
|
</label>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
Recommended IDE setup:
|
||||||
|
<a href="https://code.visualstudio.com/" target="_blank">VSCode</a>
|
||||||
|
+
|
||||||
|
<template v-if="!useScriptSetup">
|
||||||
|
<a
|
||||||
|
href="https://marketplace.visualstudio.com/items?itemName=octref.vetur"
|
||||||
|
target="_blank"
|
||||||
|
>Vetur</a>
|
||||||
|
+
|
||||||
|
<a
|
||||||
|
href="https://marketplace.visualstudio.com/items?itemName=znck.vue-language-features"
|
||||||
|
target="_blank"
|
||||||
|
>Vue DX</a>
|
||||||
|
</template>
|
||||||
|
<template v-else>
|
||||||
|
<a href="https://github.com/johnsoncodehk/volar" target="_blank">Volar</a>
|
||||||
|
</template>
|
||||||
|
</p>
|
||||||
|
<p v-if="useTsPlugin">
|
||||||
|
tsconfig setup:
|
||||||
|
<br />1. Install and add
|
||||||
|
<code>@vuedx/typescript-plugin-vue</code> to tsconfig plugins
|
||||||
|
<br />2. Delete <code>src/shims-vue.d.ts</code>
|
||||||
|
<br />3. Open
|
||||||
|
<code>src/main.ts</code> in VSCode
|
||||||
|
<br />4. Open VSCode command input
|
||||||
|
<br />5. Search and run "Select TypeScript version" -> "Use workspace version"
|
||||||
|
</p>
|
||||||
<button @click="count++">count is: {{ count }}</button>
|
<button @click="count++">count is: {{ count }}</button>
|
||||||
<p>Edit <code>components/HelloWorld.vue</code> to test hot module replacement.</p>
|
<p>
|
||||||
|
Edit
|
||||||
|
<code>components/HelloWorld.vue</code> to test hot module replacement.
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
<a href="https://vitejs.dev/guide/features.html" target="_blank">Vite Docs</a> |
|
||||||
|
<a href="https://v3.vuejs.org/" target="_blank">Vue 3 Docs</a>
|
||||||
|
</p>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script lang="ts">
|
||||||
export default {
|
import { ref, defineComponent } from 'vue'
|
||||||
|
export default defineComponent({
|
||||||
name: 'HelloWorld',
|
name: 'HelloWorld',
|
||||||
props: {
|
props: {
|
||||||
msg: String
|
msg: {
|
||||||
},
|
type: String,
|
||||||
data() {
|
required: true
|
||||||
return {
|
|
||||||
count: 0
|
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
setup: () => {
|
||||||
|
const count = ref(0)
|
||||||
|
const useScriptSetup = ref(false);
|
||||||
|
const useTsPlugin = ref(false);
|
||||||
|
return { count, useScriptSetup, useTsPlugin }
|
||||||
}
|
}
|
||||||
}
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
a {
|
||||||
|
color: #42b983;
|
||||||
|
}
|
||||||
|
|
||||||
|
label {
|
||||||
|
margin: 0 0.5em;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
code {
|
||||||
|
background-color: #eee;
|
||||||
|
padding: 2px 4px;
|
||||||
|
border-radius: 4px;
|
||||||
|
color: #304455;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
@ -2,12 +2,12 @@ import { createApp } from 'vue'
|
|||||||
import App from './App.vue'
|
import App from './App.vue'
|
||||||
// vite 会编译 import 的形式;所以 electron 及 node.js 内置模块用 require 形式
|
// vite 会编译 import 的形式;所以 electron 及 node.js 内置模块用 require 形式
|
||||||
const { ipcRenderer } = require('electron')
|
const { ipcRenderer } = require('electron')
|
||||||
import { store, isdev } from '/utils/index'
|
// import { store, isdev } from '/utils/index'
|
||||||
|
|
||||||
import './index.css'
|
import './index.css'
|
||||||
|
|
||||||
console.log('ipcRenderer:', ipcRenderer)
|
console.log('ipcRenderer:', ipcRenderer)
|
||||||
console.log('Store', store)
|
// console.log('Store', store)
|
||||||
console.log('electron is dev', isdev)
|
// console.log('electron is dev', isdev)
|
||||||
|
|
||||||
createApp(App as any).mount('#app').$nextTick(window.ClosePreloadLoading)
|
createApp(App as any).mount('#app').$nextTick(window.ClosePreloadLoading)
|
||||||
|
5
src/render/shims-vue.d.ts
vendored
Normal file
5
src/render/shims-vue.d.ts
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
declare module '*.vue' {
|
||||||
|
import { DefineComponent } from 'vue'
|
||||||
|
const component: DefineComponent<{}, {}, any>
|
||||||
|
export default component
|
||||||
|
}
|
9
src/render/shims.d.ts
vendored
9
src/render/shims.d.ts
vendored
@ -1,9 +0,0 @@
|
|||||||
declare module '*.vue' {
|
|
||||||
import Vue from 'vue'
|
|
||||||
export default Vue
|
|
||||||
}
|
|
||||||
|
|
||||||
interface Window {
|
|
||||||
/** 关闭预加载动画 */
|
|
||||||
ClosePreloadLoading: () => void
|
|
||||||
}
|
|
4
src/render/source.d.ts
vendored
4
src/render/source.d.ts
vendored
@ -1,4 +0,0 @@
|
|||||||
declare const React: string
|
|
||||||
declare module '*.json'
|
|
||||||
declare module '*.png'
|
|
||||||
declare module '*.jpg'
|
|
11
src/render/typings.d.ts
vendored
Normal file
11
src/render/typings.d.ts
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
|
||||||
|
// declare const React: string
|
||||||
|
declare module '*.json'
|
||||||
|
declare module '*.png'
|
||||||
|
declare module '*.jpg'
|
||||||
|
|
||||||
|
|
||||||
|
interface Window {
|
||||||
|
/** 关闭预加载动画 */
|
||||||
|
ClosePreloadLoading: () => void
|
||||||
|
}
|
@ -1,10 +1,10 @@
|
|||||||
{
|
{
|
||||||
"compilerOptions": {
|
"compilerOptions": {
|
||||||
"target": "esnext",
|
"target": "ESNext",
|
||||||
"module": "UMD",
|
"module": "UMD",
|
||||||
"moduleResolution": "node",
|
"moduleResolution": "node",
|
||||||
"importHelpers": true,
|
"importHelpers": true,
|
||||||
"jsx": "react",
|
"jsx": "preserve",
|
||||||
"esModuleInterop": true,
|
"esModuleInterop": true,
|
||||||
"resolveJsonModule": true,
|
"resolveJsonModule": true,
|
||||||
"sourceMap": true,
|
"sourceMap": true,
|
||||||
|
109
vite.config.ts
109
vite.config.ts
@ -1,68 +1,71 @@
|
|||||||
/**
|
import { defineConfig } from 'vite'
|
||||||
* 参考链接: https://github.com/vitejs/vite/blob/master/src/node/config.ts
|
import vue from '@vitejs/plugin-vue'
|
||||||
*/
|
|
||||||
import { join, sep } from 'path'
|
import { join, sep } from 'path'
|
||||||
import { UserConfig } from 'vite'
|
|
||||||
import dotenv from 'dotenv'
|
import dotenv from 'dotenv'
|
||||||
|
|
||||||
dotenv.config({ path: join(__dirname, '.env') })
|
dotenv.config({ path: join(__dirname, '.env') })
|
||||||
const root = join(__dirname, 'src/render')
|
const root = join(__dirname, 'src/render')
|
||||||
|
|
||||||
const config: UserConfig = {
|
// https://vitejs.dev/config/
|
||||||
|
export default defineConfig({
|
||||||
|
plugins: [vue()],
|
||||||
root,
|
root,
|
||||||
port: +process.env.PORT,
|
// base: './',
|
||||||
base: './',
|
server: {
|
||||||
outDir: join(__dirname, 'dist/render'),
|
port: +process.env.PORT,
|
||||||
alias: {
|
},
|
||||||
// 别名必须以 / 开头、结尾
|
resolve: {
|
||||||
// '/@/': root, -- vite 内部在用,这里不能用了
|
alias: {
|
||||||
// '/root/': __dirname, -- vite 内部在用,这里不能用了
|
'@root': __dirname,
|
||||||
'/assets/': join(__dirname, 'src/render/assets'),
|
'@assets': join(__dirname, 'src/render/assets'),
|
||||||
'/components/': join(__dirname, 'src/render/components'),
|
'@components': join(__dirname, 'src/render/components'),
|
||||||
'/lib/': join(__dirname, 'src/render/lib'),
|
'@lib': join(__dirname, 'src/render/lib'),
|
||||||
'/utils/': join(__dirname, 'src/render/utils'),
|
'@utils': join(__dirname, 'src/render/utils'),
|
||||||
'/views/': join(__dirname, 'src/render/views'),
|
'@views': join(__dirname, 'src/render/views'),
|
||||||
|
},
|
||||||
},
|
},
|
||||||
optimizeDeps: {
|
optimizeDeps: {
|
||||||
// 这里不加也没事,用 require 的形式就能避开 import 被编译成 /@modules/fs?import
|
// 这里不加也没事,用 require 的形式就能避开 import 被编译成 /@modules/fs?import
|
||||||
// allowNodeBuiltins: ['electron-is-dev', 'electron-store', 'electron']
|
// allowNodeBuiltins: ['electron-is-dev', 'electron-store', 'electron']
|
||||||
},
|
},
|
||||||
rollupInputOptions: {
|
build: {
|
||||||
external: [
|
outDir: join(__dirname, 'dist/render'),
|
||||||
'crypto',
|
rollupOptions: {
|
||||||
'assert',
|
output: {
|
||||||
'fs',
|
// format: 'commonjs',
|
||||||
'util',
|
},
|
||||||
'os',
|
external: [
|
||||||
'events',
|
'crypto',
|
||||||
'child_process',
|
'assert',
|
||||||
'http',
|
'fs',
|
||||||
'https',
|
'util',
|
||||||
'path',
|
'os',
|
||||||
'electron',
|
'events',
|
||||||
],
|
'child_process',
|
||||||
plugins: [
|
'http',
|
||||||
{
|
'https',
|
||||||
name: '@rollup/plugin-cjs2esm',
|
'path',
|
||||||
transform(code, filename) {
|
'electron',
|
||||||
if (filename.includes(`${sep}node_modules${sep}`)) {
|
],
|
||||||
|
plugins: [
|
||||||
|
{
|
||||||
|
name: '@rollup/plugin-cjs2esm',
|
||||||
|
transform(code, filename) {
|
||||||
|
if (filename.includes(`${sep}node_modules${sep}`)) {
|
||||||
|
return code
|
||||||
|
}
|
||||||
|
|
||||||
|
const cjsRegexp = /(const|let|var)[\n\s]+(\w+)[\n\s]*=[\n\s]*require\(["|'](.+)["|']\)/g
|
||||||
|
const res = code.match(cjsRegexp)
|
||||||
|
if (res) {
|
||||||
|
// const Store = require('electron-store') -> import Store from 'electron-store'
|
||||||
|
code = code.replace(cjsRegexp, `import $2 from '$3'`)
|
||||||
|
}
|
||||||
return code
|
return code
|
||||||
}
|
},
|
||||||
|
}
|
||||||
const cjsRegexp = /(const|let|var)[\n\s]+(\w+)[\n\s]*=[\n\s]*require\(["|'](.+)["|']\)/g
|
],
|
||||||
const res = code.match(cjsRegexp)
|
},
|
||||||
if (res) {
|
|
||||||
// const Store = require('electron-store') -> import Store from 'electron-store'
|
|
||||||
code = code.replace(cjsRegexp, `import $2 from '$3'`)
|
|
||||||
}
|
|
||||||
return code
|
|
||||||
},
|
|
||||||
}
|
|
||||||
],
|
|
||||||
},
|
},
|
||||||
rollupOutputOptions: {
|
})
|
||||||
format: 'commonjs',
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
export default config
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user