本文主要是介绍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
遇到相同属性名的时候,如果属性值是纯对象或集合的时候,会合并属性值
参考资料
https://lodash.com/docs
http://stackoverflow.com/questions/19965844/lodash-difference-between-extend-assign-and-merge
原文链接:https://scarletsky.github.io/2016/04/02/assign-vs-extend-vs-merge-in-lodash/
这篇关于Lodash 中 assign,extend 和 merge 的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!