Lodash 中 assign,extend 和 merge 的区别
文章目录
简介
我们经常在别人的代码中看见 assign
,extend
,merge
函数,这三个函数用起来很相似,都是合并源对象的属性到目标对象中。
既然都是合并对象,为什么还分三个不同的函数呢?它们之间到底有什么区别呢?
assign(object, [sources])
我们先看看官方网站上面的定义:
Assigns own enumerable string keyed properties of source objects to the destination object. Source objects are applied from left to right. Subsequent sources overwrite property assignments of previous sources.
把源对象(sources)的属性分配到目标对象(object),源对象会从左往右地调用,后面对象的属性会覆盖前面的。
看看下面的例子:
|
|
extend(object, [sources])
在 3.x 版本中,extend
是 assign
的别名,它们的作用是一模一样的。
在 4.x 版本中,extend
是 assignIn
的别名,和 assign
有点区别。
官方定义如下:
This method is like _.assign except that it iterates over own and inherited source properties.
在上面的例子中,我们知道 assign
函数不会把原型链上的属性合并到目标对象,而 extend
或 assignIn
函数则会!
|
|
merge(object, [sources])
我们看看 merge
函数的定义:
This method is like _.assign except that it recursively merges own and inherited enumerable string keyed properties of source objects into the destination object. Source properties that resolve to undefined are skipped if a destination value exists. Array and plain object properties are merged recursively.Other objects and value types are overridden by assignment. Source objects are applied from left to right. Subsequent sources overwrite property assignments of previous sources.
merge
也和 assign
类似,不同的地方在于 merge
遇到相同属性的时候,如果属性值为纯对象(plain object)或者集合(collection)时,不是用后面的属性值去覆盖前面的属性值,而是会把前后两个属性值合并。
如果源对象的属性值为 undefined
,则会忽略该属性。
|
|
总结
相同之处
- 都可以用来合并对象
- 都会修改原来的对象 (如果原来的对象是作为函数的第一个参数的话)
不同之处
assign
函数不会处理原型链上的属性,也不会合并相同的属性,而是用后面的属性值覆盖前面的属性值extend
- 3.x 版本中和
assign
一样 - 4.x 版本中会合并原型链上的属性
- 3.x 版本中和
merge
遇到相同属性名的时候,如果属性值是纯对象或集合的时候,会合并属性值
参考资料
文章作者 scarletsky
上次更新 2019-04-30 (95a170d)