在JavaScript中有两种不同的方法来创建一个空对象:

var objectA = {}
var objectB = new Object()

脚本引擎处理它们的方式有什么不同吗?有理由使用其中一种而不是另一种吗?

同样,也可以使用不同的语法创建一个空数组:

var arrayA = []
var arrayB = new Array()

当前回答

好吧,只有两种不同的方法来做同样的事情!一个叫对象字面值,另一个是函数构造函数!

但继续读下去,我有几件事想和大家分享:

使用{}使您的代码更具可读性,而创建Object实例或其他内置函数不推荐…

另外,Object函数作为函数可以获得参数,比如Object(params)…但是{}是JavaScript中开始一个对象的纯粹方式…

使用object literal可以让你的代码看起来更干净,对其他开发人员来说更容易阅读,而且它与JavaScript的最佳实践是内联的……

虽然Javascript中的Object几乎可以是任何东西,{}只指向Javascript对象,为了测试它的工作方式,请在Javascript代码或控制台中执行以下操作:

var n = new Object(1); //Number {[[PrimitiveValue]]: 1}

令人惊讶的是,它正在创建一个数字!

var a = new Object([1,2,3]); //[1, 2, 3]

这是创建Array!

var s = new Object('alireza'); //String {0: "a", 1: "l", 2: "i", 3: "r", 4: "e", 5: "z", 6: "a", length: 7, [[PrimitiveValue]]: "alireza"}

以及String的奇怪结果!

所以如果你正在创建一个对象,建议使用object literal,有一个标准的代码,避免任何类似上述的代码事故,而且在性能上使用{}在我的经验是更好的!

其他回答

Var Obj = {};

这是最常用和最简单的方法。

使用

var Obj = new Obj() 

不是首选。

不需要使用new Object()。

为了简单性、可读性和执行速度,请使用第一个方法(对象字面量方法)。

var objectA = {}

更快,而且根据我的经验,更常用,所以最好采用“标准”并节省一些输入。

这本质上是一样的。你觉得什么方便就用什么。

我相信{}在这里的一个Javascript视频中被推荐为一个很好的编码约定。新对于伪经典继承是必要的。var obj = {};Way有助于提醒您,这不是一个经典的面向对象语言,而是一个原型语言。因此,只有在使用构造函数时才真正需要new。例如:

var Mammal = function (name) {
  this.name = name;
};

Mammal.prototype.get_name = function () {
  return this.name;
}

Mammal.prototype.says = function() {
  return this.saying || '';
}

然后它是这样使用的:

var aMammal = new Mammal('Me warm-blooded');
var name = aMammal.get_name();

使用{}而不是new Object的另一个优点是你可以用它来做json风格的对象字面量。

对象和数组文字语法{}/[]是在JavaScript 1.2中引入的,因此在Netscape Navigator 4.0之前的版本中不可用(并将产生语法错误)。

我的手指仍然默认为new Array(),但我已经很老了。值得庆幸的是,网景3不是今天许多人不得不考虑的浏览器……