繁体   English   中英

如何在 electron 中通过 IPC 发送复杂的 object?

[英]How to send complex object over IPC in electron?

我正在使用ipcRenderer.send()将一组对象发送回ipcMain 这是我的代码:

const loadData = async () => {
    let promises = [];
    ['stocks', 'crypto', 'vehicles', 'property'].forEach(item => {
        promises.push(getTableData(item))
    })
    let data = {}
    await Promise.allSettled(promises).then(results => {
        for (let i in results) {
            var result = results[i]
            if (result.status === 'fulfilled') {
                console.log(result.value.type)
                // result.value.data will be an array of objects
                console.log(result.value.data)
                data[result.value.type] = result.value.data
            } else {
                console.error(result)
            }
        }
    }).finally(_ => {
        console.log(data)
        ipcRenderer.send('asynchronous-message', data)
    })
}

当通过console.log打印result.value.data时,它会显示正确的数据(来自 SQL 查询):

{ stocks: [{id: 1, ticker: "BRK.B", action: "ADD", price: 173.97, shares: 6}, ...], ...}

但是,当它在ipcMain.on('asynchronous-message', ...)中打印时,它会为值打印空 arrays :

{ stocks: [], crypto: [], vehicles: [], property: [] }

如何发送带有复杂 object 的 IPC 消息? 它没有被正确序列化吗?


作为参考,这是我的ipcMain.on('asynchronous-message', ...)代码:

ipcMain.on('asynchronous-message', async (event, data) => {
  console.log(data)
})

此外,这里是getTableData()

const getTableData = (table) => {
    let toReturn = {
        type: `${table}`,
        data: []
    }
    return new Promise((resolve, reject) => {
        try {
            db.run(`PRAGMA table_info('${table}');`, err => {
                if (err) {
                    reject(err)
                } else {
                    db.each(`SELECT * FROM ${table}`, (err, row) => {
                        if (err) {
                            reject(err)
                        } else {
                            toReturn.data.push(row)
                        }
                    })
                    resolve(toReturn)
                }
            })
        } catch (e) {
            reject(e)
        }
    })
}

其中每一行都是一个 object,如下所示:

{id: 1, ticker: "AAPL", action: "ADD", price: 100.0,
shares: 10, datetime: "2020-05-14 23:24:50", platform: ""}

在@Estradiaz 的帮助下,我意识到 promise 在 SQL 查询被处理之前就已经解决了。 为了解决这个问题,我从使用db.each()切换到db.all() 这是我更新的getTableData()

const getTableData = (table) => {
    let toReturn = {
        type: `${table}`,
        data: []
    }
    return new Promise((resolve, reject) => {
        try {
            DB.run(`PRAGMA table_info('${table}');`, err => {
                if (err) {
                    console.error(err)
                    reject(err)
                } else {
                    DB.all(`SELECT * FROM ${table}`, (err, rows) => {
                        if (err) {
                            console.error(err)
                            reject(err)
                        } else {
                            toReturn.data = rows
                            resolve(toReturn)
                        }
                    })
                }
            })
        } catch (e) {
            console.error(e)
            reject(e)
        }
    })
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM