Node 中的大括号(大括号).js 'require' 语句

我试图理解下面两个“要求”语句之间的区别。

具体来说,s包裹的目的是什么?{ }ipcMain

const electron = require('electron')

const {ipcMain} = require('electron')

它们似乎都分配了模块的内容,但它们的功能显然不同。electron

任何人都可以透露一些光明吗?


答案 1

第二个示例使用解构。

这将调用从所需模块导出的特定变量(包括函数)。

例如(函数.js):

module.exports = {
   func1,
   func2
}

包含在您的文件中:

const { func1, func2 } = require('./functions')

现在您可以单独调用它们,

func1()
func2()

相反:

const Functions = require('./functions')

使用点表示法调用:

Functions.func1()
Functions.func2()

希望这有帮助。

你可以在这里阅读有关解构的信息,它是ES6中非常有用的部分,可以与数组和对象一起使用。


答案 2

使用 时,模块将作为 。const electron = require('electron')ipcMainelectron.ipcMain

与模块将作为.const {ipcMain} = require('electron')ipcMainipcMain

此构造称为对象析构,其实现与 Python 构造相同

from library import ...

在其基本形式中,它允许您直接引用对象的属性:

var o = {prop1: '1', prop2: 2}
var {prop1, prop2} = o
console.log(prop1) // '1' (same as o.prop1)
console.log(prop2) // 2 (same as o.prop2)

检查:

const {ipcMain} = require('electron')
const myElectron = require('electron')
const myipcMain = myElectron.ipcMain
console.log(myipcMain===ipcMain) // true

您可以使用解构赋值来导入 JavaScript 对象的多个属性,例如:

const { app, BrowserWindow, ipcMain } = require('electron')

如果使用不存在的属性,则会将其设置为“并且不会收到错误”。undefined

const {app, BrowserWindow, ipcMain, doesntExist} = require('electron')
console.log(doesntExist) // undefined

另请参阅:var { ... } = ... 语句中的大括号有什么作用?