Fix(electron): Fix the bug that the page cannot be loaded after refreshing
This commit is contained in:
@@ -4,6 +4,7 @@ import { electronApp, optimizer, is } from '@electron-toolkit/utils'
|
|||||||
import icon from '../../build/icon.ico?asset'
|
import icon from '../../build/icon.ico?asset'
|
||||||
import path from 'node:path'
|
import path from 'node:path'
|
||||||
import url from 'node:url'
|
import url from 'node:url'
|
||||||
|
import fs from 'fs'
|
||||||
|
|
||||||
let mainWindow: BrowserWindow
|
let mainWindow: BrowserWindow
|
||||||
|
|
||||||
@@ -105,8 +106,19 @@ void app.whenReady().then(() => {
|
|||||||
protocol.handle('local', (request) => {
|
protocol.handle('local', (request) => {
|
||||||
const { host } = new URL(request.url)
|
const { host } = new URL(request.url)
|
||||||
if (host === 'oxygen.fatweb.top') {
|
if (host === 'oxygen.fatweb.top') {
|
||||||
const filePath = request.url.slice('local://oxygen.fatweb.top/'.length)
|
let filePath = request.url.slice('local://oxygen.fatweb.top/'.length)
|
||||||
return net.fetch(url.pathToFileURL(filePath).toString())
|
if (fs.existsSync(filePath)) {
|
||||||
|
return net.fetch(url.pathToFileURL(filePath).toString())
|
||||||
|
}
|
||||||
|
|
||||||
|
filePath = join(join(__dirname, '../renderer'), filePath)
|
||||||
|
if (fs.existsSync(filePath)) {
|
||||||
|
return net.fetch(url.pathToFileURL(filePath).toString())
|
||||||
|
}
|
||||||
|
|
||||||
|
return net.fetch(
|
||||||
|
url.pathToFileURL(join(__dirname, '../renderer/index.html')).toString()
|
||||||
|
)
|
||||||
} else {
|
} else {
|
||||||
const filePath = request.url.slice('local://'.length)
|
const filePath = request.url.slice('local://'.length)
|
||||||
return net.fetch(url.pathToFileURL(filePath).toString())
|
return net.fetch(url.pathToFileURL(filePath).toString())
|
||||||
|
|||||||
Reference in New Issue
Block a user