在Electron中处理表单的正确方法是什么? [英] What's the proper way to handle forms in Electron?

查看:372
本文介绍了在Electron中处理表单的正确方法是什么?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

表单html和Submit事件是渲染器的一部分。
提交的数据应在主流程中可用。
提交表单并使数据在main.js中可访问的正确方法是什么?

The form html and submit event is part of the "renderer". The submitted data should be available in the main process. What's the proper way to submit the form and make that data accessible in main.js ?

我应该简单地使用远程模块来传递数据吗?到main.js中的函数还是有更好的方法?

Should I simply use the "remote" module to pass the data to a function from main.js or is there a better approach?

推荐答案

我们使用服务(Angular)处理表单数据在一个窗口中。然后根据需要通知远程

We use a service (Angular) to process form data in a window. Then notify the remote, if needed.

从您的 renderer ,您可以将数据发送到 ipc ,然后在您的 main.js 您捕获了此事件和传递的表单数据:

From your renderer you can send data to the ipc, then in your main.js you catch this event and the passed form data:

// renderer.js
let ipcRenderer = require('electron').ipcRenderer;
ipcRenderer.send('submitForm', formData);

// main.js
ipcMain.on('submitForm', function(event, data) {
   // Access form data here
});






您还可以将邮件发送回<$ main.js 中的c $ c> renderer


You can also send messages back to the renderer from the main.js.

同步

// main.js
ipcMain.on('submitForm', function(event, data) {
   // Access form data here
   event.returnValue = {"any": "value"};
});

异步

// main.js
ipcMain.on('submitForm', function(event, data) {
   // Access form data here
   event.sender.send('formSubmissionResults', results);
});

// renderer.js
ipcRenderer.on('formSubmissionResults', function(event, args) {
   let results = args.body;
});

这篇关于在Electron中处理表单的正确方法是什么?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆