feat:打开目录
This commit is contained in:
parent
20228ddb91
commit
8bcc7ccb1f
|
@ -14,6 +14,6 @@
|
||||||
<div style="border:2px solid black;border-radius:3px;padding:5px;display:inline-block" draggable="true" id="drag2">Drag
|
<div style="border:2px solid black;border-radius:3px;padding:5px;display:inline-block" draggable="true" id="drag2">Drag
|
||||||
me - File 2
|
me - File 2
|
||||||
</div>
|
</div>
|
||||||
<script src="renderer.js"></script>
|
<script src="src/comment/renderer.js"></script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
6
main.js
6
main.js
|
@ -1,9 +1,9 @@
|
||||||
// npm start
|
// npm start
|
||||||
const { app, BrowserWindow , ipcMain } = require('electron')
|
const { app,Menu, BrowserWindow , ipcMain } = require('electron')
|
||||||
const path = require('path')
|
const path = require('path')
|
||||||
const fs = require('fs')
|
const fs = require('fs')
|
||||||
const https = require('https')
|
const https = require('https')
|
||||||
|
const template = require('./src/comment/TopMenu.js')
|
||||||
// electorn
|
// electorn
|
||||||
const createWindow = () => {
|
const createWindow = () => {
|
||||||
// Create the browser window.
|
// Create the browser window.
|
||||||
|
@ -17,8 +17,10 @@ const createWindow = () => {
|
||||||
// 加载 index.html
|
// 加载 index.html
|
||||||
win.loadFile('index.html')
|
win.loadFile('index.html')
|
||||||
// win.loadURL('http://localhost/show/sync?current=1&pageSize=5')
|
// win.loadURL('http://localhost/show/sync?current=1&pageSize=5')
|
||||||
|
|
||||||
// 打开开发工具
|
// 打开开发工具
|
||||||
win.webContents.openDevTools()
|
win.webContents.openDevTools()
|
||||||
|
Menu.setApplicationMenu(Menu.buildFromTemplate(template.template))
|
||||||
}
|
}
|
||||||
const iconName = path.join(__dirname, 'iconForDragAndDrop.png')
|
const iconName = path.join(__dirname, 'iconForDragAndDrop.png')
|
||||||
// const icon = fs.createWriteStream(iconName)
|
// const icon = fs.createWriteStream(iconName)
|
||||||
|
|
|
@ -1,7 +1,10 @@
|
||||||
|
// 预加载脚本 在上下文隔离渲染器进程中导入 Node.js 和 Electron 模块的概念
|
||||||
// 所有的 Node.js API接口 都可以在 preload 进程中被调用.
|
// 所有的 Node.js API接口 都可以在 preload 进程中被调用.
|
||||||
// 它拥有与Chrome扩展一样的沙盒。
|
// 它拥有与Chrome扩展一样的沙盒。
|
||||||
const { contextBridge, ipcRenderer } = require('electron/renderer')
|
const { contextBridge, ipcRenderer } = require('electron/renderer')
|
||||||
|
// 读取文件夹中文件,并传给渲染层
|
||||||
|
// import { unlink } from 'node:fs/promises';
|
||||||
contextBridge.exposeInMainWorld('electron', {
|
contextBridge.exposeInMainWorld('electron', {
|
||||||
startDrag: (fileName) => ipcRenderer.send('ondragstart', fileName)
|
startDrag : (fileName) => ipcRenderer.send('ondragstart', fileName),
|
||||||
|
listDirFile :(fileName)=>ipcRenderer.send('ondragstart', fileName)
|
||||||
})
|
})
|
12
preload1.js
12
preload1.js
|
@ -1,12 +0,0 @@
|
||||||
// 所有的 Node.js API接口 都可以在 preload 进程中被调用.
|
|
||||||
// 它拥有与Chrome扩展一样的沙盒。
|
|
||||||
window.addEventListener('DOMContentLoaded', () => {
|
|
||||||
const replaceText = (selector, text) => {
|
|
||||||
const element = document.getElementById(selector)
|
|
||||||
if (element) element.innerText = text
|
|
||||||
}
|
|
||||||
|
|
||||||
for (const dependency of ['chrome', 'node', 'electron']) {
|
|
||||||
replaceText(`${dependency}-version`, process.versions[dependency])
|
|
||||||
}
|
|
||||||
})
|
|
|
@ -1,9 +0,0 @@
|
||||||
const { contextBridge, ipcRenderer } = require('electron')
|
|
||||||
|
|
||||||
contextBridge.exposeInMainWorld('versions', {
|
|
||||||
node: () => process.versions.node,
|
|
||||||
chrome: () => process.versions.chrome,
|
|
||||||
electron: () => process.versions.electron,
|
|
||||||
ping: () => ipcRenderer.invoke('ping')
|
|
||||||
// 除函数之外,我们也可以暴露变量
|
|
||||||
})
|
|
|
@ -1,4 +0,0 @@
|
||||||
const func = async () => {
|
|
||||||
const response = await window.versions.ping()
|
|
||||||
console.log(response) // 打印 'pong'
|
|
||||||
}
|
|
|
@ -0,0 +1,9 @@
|
||||||
|
// https://nodejs.org/docs/latest-v16.x/api/fs.html
|
||||||
|
import { readdir } from 'node:fs/promises';
|
||||||
|
try {
|
||||||
|
const files = await readdir("/home/shixiaohua");
|
||||||
|
for (const file of files)
|
||||||
|
console.log(file);
|
||||||
|
} catch (err) {
|
||||||
|
console.error(err);
|
||||||
|
}
|
|
@ -0,0 +1,122 @@
|
||||||
|
const { app, Menu, shell} = require('electron')
|
||||||
|
|
||||||
|
const isMac = process.platform === 'darwin'
|
||||||
|
|
||||||
|
exports.template = [
|
||||||
|
// { role: 'appMenu' }
|
||||||
|
...(isMac
|
||||||
|
? [{
|
||||||
|
label: app.name,
|
||||||
|
submenu: [
|
||||||
|
{ role: 'about' },
|
||||||
|
{ type: 'separator' },
|
||||||
|
{ role: 'services' },
|
||||||
|
{ type: 'separator' },
|
||||||
|
{ role: 'hide' },
|
||||||
|
{ role: 'hideOthers' },
|
||||||
|
{ role: 'unhide' },
|
||||||
|
{ type: 'separator' },
|
||||||
|
{ role: 'quit' }
|
||||||
|
]
|
||||||
|
}]
|
||||||
|
: []),
|
||||||
|
// { role: 'fileMenu' }
|
||||||
|
{
|
||||||
|
label: 'File',
|
||||||
|
submenu: [
|
||||||
|
{label:'打开目录',
|
||||||
|
click: async () => {
|
||||||
|
const { dialog } = require('electron')
|
||||||
|
dialog.showOpenDialog({
|
||||||
|
properties: ['openDirectory']
|
||||||
|
}).then(result => {
|
||||||
|
console.log(result.canceled)
|
||||||
|
// 不取消就发送目录
|
||||||
|
if (!result.canceled)
|
||||||
|
console.log(result.filePaths)
|
||||||
|
}).catch(err => {
|
||||||
|
console.log(err)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
},
|
||||||
|
isMac ? { role: 'close' } : { role: 'quit' },
|
||||||
|
isMac ? { role: 'open' } : { role: 'open' }
|
||||||
|
]
|
||||||
|
},
|
||||||
|
// { role: 'editMenu' }
|
||||||
|
{
|
||||||
|
label: 'Edit',
|
||||||
|
submenu: [
|
||||||
|
{ role: 'undo' },
|
||||||
|
{ role: 'redo' },
|
||||||
|
{ type: 'separator' },// 分割线
|
||||||
|
{ role: 'cut' },
|
||||||
|
{ role: 'copy' },
|
||||||
|
{ role: 'paste' },
|
||||||
|
...(isMac
|
||||||
|
? [
|
||||||
|
{ role: 'pasteAndMatchStyle' },
|
||||||
|
{ role: 'delete' },
|
||||||
|
{ role: 'selectAll' },
|
||||||
|
{ type: 'separator' },
|
||||||
|
{
|
||||||
|
label: 'Speech',
|
||||||
|
submenu: [
|
||||||
|
{ role: 'startSpeaking' },
|
||||||
|
{ role: 'stopSpeaking' }
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
: [
|
||||||
|
{ role: 'delete' },
|
||||||
|
{ type: 'separator' },
|
||||||
|
{ role: 'selectAll' }
|
||||||
|
])
|
||||||
|
]
|
||||||
|
},
|
||||||
|
// { role: 'viewMenu' }
|
||||||
|
{
|
||||||
|
label: 'View',
|
||||||
|
submenu: [
|
||||||
|
{ role: 'reload' },
|
||||||
|
{ role: 'forceReload' },
|
||||||
|
{ role: 'toggleDevTools' },
|
||||||
|
{ type: 'separator' },
|
||||||
|
{ role: 'resetZoom' },
|
||||||
|
{ role: 'zoomIn' },
|
||||||
|
{ role: 'zoomOut' },
|
||||||
|
{ type: 'separator' },
|
||||||
|
{ role: 'togglefullscreen' }
|
||||||
|
]
|
||||||
|
},
|
||||||
|
// { role: 'windowMenu' }
|
||||||
|
{
|
||||||
|
label: 'Window',
|
||||||
|
submenu: [
|
||||||
|
{ role: 'minimize' },
|
||||||
|
{ role: 'zoom' },
|
||||||
|
...(isMac
|
||||||
|
? [
|
||||||
|
{ type: 'separator' },
|
||||||
|
{ role: 'front' },
|
||||||
|
{ type: 'separator' },
|
||||||
|
{ role: 'window' }
|
||||||
|
]
|
||||||
|
: [
|
||||||
|
{ role: 'close' }
|
||||||
|
])
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
role: 'help',
|
||||||
|
submenu: [
|
||||||
|
{
|
||||||
|
label: 'Learn More',
|
||||||
|
click: async () => {
|
||||||
|
const { shell } = require('electron')
|
||||||
|
await shell.openExternal('http://www.huaruyu.com')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
|
@ -1,3 +1,4 @@
|
||||||
|
// html中使用的js代码 之后用react替换
|
||||||
document.getElementById('drag1').ondragstart = (event) => {
|
document.getElementById('drag1').ondragstart = (event) => {
|
||||||
event.preventDefault()
|
event.preventDefault()
|
||||||
window.electron.startDrag('drag-and-drop-1.md')
|
window.electron.startDrag('drag-and-drop-1.md')
|
Loading…
Reference in New Issue