add preload.js

master
hocili 2021-03-10 18:01:42 +08:00
parent da802dd8fb
commit f8bc0cdb6a
4 changed files with 33 additions and 6 deletions

View File

@ -6,8 +6,8 @@
"dev": "vite", "dev": "vite",
"build": "vite build", "build": "vite build",
"serve": "vite preview", "serve": "vite preview",
"electron:dev": "NODE_ENV=development electron index.js", "electron:dev": "cross-env NODE_ENV=development electron index.js",
"electron:build": "vite build && tsc -p tsconfig.electron.json --outDir dist/main && electron-builder" "electron:build": "rm -rf dist && vite build && tsc -p tsconfig.electron.json && electron-builder"
}, },
"dependencies": { "dependencies": {
"vue": "^3.0.5" "vue": "^3.0.5"
@ -28,7 +28,8 @@
"category": "your.app.category.type" "category": "your.app.category.type"
}, },
"files": [ "files": [
"dist/**/*" "dist/main/**/*",
"dist/render/**/*"
], ],
"directories": { "directories": {
"output": "dist/release" "output": "dist/release"

View File

@ -1,16 +1,19 @@
import { app, BrowserWindow } from 'electron' import { app, BrowserWindow } from 'electron'
import {join} from "path";
function createWindow() { function createWindow() {
const win = new BrowserWindow({ const win = new BrowserWindow({
width: 800, width: 800,
height: 600, height: 600,
webPreferences: { webPreferences: {
nodeIntegration: true nodeIntegration: true,
preload: join(__dirname, 'preload.js')
} }
}) })
if (process.env.NODE_ENV === 'development') { if (process.env.NODE_ENV === 'development') {
win.loadURL('http://localhost:3000/') win.loadURL('http://localhost:3000/')
win.webContents.openDevTools()
} else { } else {
win.loadFile('dist/render/index.html') win.loadFile('dist/render/index.html')
} }

20
src/main/preload.js Normal file
View File

@ -0,0 +1,20 @@
const {ipcRenderer, contextBridge} = require('electron')
contextBridge.exposeInMainWorld('ipcRenderer', {
send: (channel, data) => {
// whitelist channels
let validChannels = ['toMain']
if (validChannels.includes(channel)) {
ipcRenderer.send(channel, data)
}
ipcRenderer.send(channel, data)
},
receive: (channel, func) => {
let validChannels = ['fromMain']
if (validChannels.includes(channel)) {
// Deliberately strip event as it includes `sender`
ipcRenderer.on(channel, (event, ...args) => func(...args))
}
ipcRenderer.on(channel, (event, ...args) => func(...args))
}
})

View File

@ -5,9 +5,12 @@
"moduleResolution": "node", "moduleResolution": "node",
"strict": true, "strict": true,
"resolveJsonModule": true, "resolveJsonModule": true,
"esModuleInterop": true "esModuleInterop": true,
"allowJs": true,
"outDir": "dist/main"
}, },
"include": [ "include": [
"src/main/app.ts" "src/main/app.ts",
"src/main/preload.js",
] ]
} }