Javascript ES6该功能的实现?
此函数循环遍历对象数组,并将对象作为第二个参数 如果Javascript ES6该功能的实现?,javascript,arrays,loops,object,ecmascript-6,Javascript,Arrays,Loops,Object,Ecmascript 6,此函数循环遍历对象数组,并将对象作为第二个参数 如果firstname值匹配,它将循环遍历对象数组,并将其替换为作为第二个参数传入的对象 我确信有更好的方法使用ES6 spread运算符实现此函数,但我在实现它时遇到了困难 const foo=(arr,obj)=>{ 常量tempArray=arr.map((项目,i)=>{ if(arr[i].name==obj.name){ 返回obj }否则{ 返回arr[i] } }) 返回临时数组 } 常量arrOfObjx=[ { “姓名”:“乔
firstname
值匹配,它将循环遍历对象数组,并将其替换为作为第二个参数传入的对象
我确信有更好的方法使用ES6 spread运算符实现此函数,但我在实现它时遇到了困难
const foo=(arr,obj)=>{
常量tempArray=arr.map((项目,i)=>{
if(arr[i].name==obj.name){
返回obj
}否则{
返回arr[i]
}
})
返回临时数组
}
常量arrOfObjx=[
{
“姓名”:“乔”,
“法夫莫维”:“兰博”
},
{
“姓名”:“简”,
“favMovie”:“矩阵”
},
{
“姓名”:“约翰”,
“favMovie”:“星球大战”
}
]
康斯特纽乔={
“姓名”:“乔”,
“favMovie”:“ROCKY”
}
log(foo(arrOfObjx,newJoe))
使用该项进行尝试
const tempArray = arr.map((item, i) => {
if (item.name === obj.name) {
return obj
} else {
return item
}
})
我想你甚至可以把它写成
const tempArray = arr.map((item, i) => {
return (item.name === obj.name ? obj : item)
})
不,这里没有spread操作符的用例。简化方法是删除
tempArray
变量,并使用项而不是arr[i]
:
function foo(arr, obj) {
return arr.map((item, i) => {
if ( item.name === obj.name ) {
return obj
} else {
return item
}
});
}
可以进一步缩短为
const foo = (arr, obj) =>
arr.map(item =>
item.name === obj.name ? obj : item
);