当保存的文件被覆盖/替换时,电子窗口会重新加载

时间:2018-09-19 20:24:51

标签: javascript node.js electron

因此,我编写了保存功能,并且该功能与我第一次保存文件时完全一样。但是,如果我尝试通过再次保存来覆盖文件,则文件保存会很好,但是会重新加载窗口,以清除所有输入的数据。我可以只加载保存的文件并继续编辑,但是那样会很烦人。我在任何地方都找不到有关如何解决此问题的任何信息。任何帮助将不胜感激。

function saveData(){
  let data = {}
  data.item1 = getItem1()
  data.item2 = getItem2()
  data.item3 = getItem3()
  // convert data object to a string
  let dataString = JSON.stringify(data, null, 4)
  // open save dialog and chooses path
  let savePath = dialog.showSaveDialog({filters: [{name: 'Save File', extensions: ['json']},]})
  // save file to disk
  if (savePath != undefined){
    fs.writeFile(savePath, dataString, function(err) {
    // file saved or err
    })
  }
}

这是菜单模板条目:

{ label: 'File',
  submenu: [
    { label: 'New', click: SendEvent('file-new')},
    { label: 'Open', click: SendEvent('file-open')},
    { label: 'Save', accelerator: 'CmdOrCtrl+S', click: function(){
            saveData();
      }
    },

    { label: 'Save As',
        accelerator: 'CmdOrCtrl+Shift+S',
        click: SendEvent('file-save-as')},
    { label: 'Close', click: SendEvent('file-close')},
    { type: 'separator'},
    { label: 'Quit', accelerator: 'CmdOrCtrl+Q', click: function() {app.quit();}},
    { type: 'separator' },
    { label: 'Print', accelerator: 'CmdOrCtrl+P', click(){win.webContents.print({silent: false, printBackground: false})} }
    ]
},

和getItem1函数:

function getItem1(){
    const item1 = document.getElementById('itemID').src
    return item1
}

1 个答案:

答案 0 :(得分:0)

现在我有点傻了。事实证明,重新加载的原因是因为我在保存源文件时使用electron-reload包来自动重新加载页面。当保存文件被覆盖时,这也导致页面重新加载。很高兴知道。

编辑:

您可以通过将require语句修改为类似的样子,来告诉electron-reload忽略目录:

require('electron-reload')(__dirname, {ignored: /<folder_to_be_ignored>|[\/\\]\./});

https://github.com/yan-foto/electron-reload#api