我正在尝试为我的Electron应用添加功能,允许用户在应用中打开文件,特别是纯文本文件。在查看Electron文档后,我找到了this页面。我将此代码添加到我的app.js
文件中,我在index.html
。
var fs = require('fs');
var dialog = require('electron');
$openFile = $('#openBtn');
$editor = $('#editor');
$openFile.click(function(){
dialog.showOpenDialog(function(fileNames) {
if (fileNames === undefined) return;
var fileName = fileNames[0];
fs.readFile(fileName, 'utf-8', function (err, data) {
$editor.val(data);
});
});
});
但是,当我运行此命令时,此错误会显示在控制台中:Uncaught TypeError: dialog.showOpenDialog is not a function
我尝试使用远程,但无济于事。
有谁知道如何解决这个问题? 提前致谢
答案 0 :(得分:14)
const {dialog} = require('electron').remote;
document.querySelector('#selectBtn').addEventListener('click', function (event) {
dialog.showOpenDialog({
properties: ['openFile', 'multiSelections']
}, function (files) {
if (files !== undefined) {
// handle files
}
});
});
答案 1 :(得分:1)
在主要过程中,您可以使用
const {dialog} = require('electron');
dialog.showOpenDialog({properties: ['openFile'] }).then(function (response) {
if (!response.canceled) {
// handle fully qualified file name
console.log(response.filePaths[0]);
} else {
console.log("no file selected");
}
});
响应如下:
{
canceled: false,
filePaths: [
'<fullpath>/<filename>'
]
}