var formArr = [
0:{name: “Name”, value: “111”},
1:{name: “Price”, value: “2”},
2:{name: “ProducingArea”, value: “3”},
3:{name: “ShelfLife”, value: “44”},
4:{name: “Stock”, value: “5”}
];
var obj={ };
//map循环方式
formArr.map(function (e, item) {
console.log(e.name);
obj[e.name] = e.value;
});
//$.each循环方式
$.each(formArr, function (item,e) {
console.log(e.name);
obj[e.name] = e.value;
})
//for in 循环方式
for (var item in formArr){
obj[formArr[item].name] = formArr[item].value;
};
结果打印:obj = {Name: “2”, Price: “3”, ProducingArea: “4”, ShelfLife: “5”, Stock: “6”}
二、React map:比较两个数组的值
const [userList, setUserList] = useState([]);
const [arrList, setArrList] = useState([]);
//获取搜索框接口返回的数据resUserList
const urlUser = /api/client/user/account/list?search=${keyPeruser}
;
let resUserList = await request.get(urlUser)
var obj = {}; //下列通过map将 arrList 转化为{11139(<=学号SNO),{…}(<=这是arrList数组)}的对象形式
const newArrList = arrList.map(item => {
obj[item.SNO] = item;
})
const newList = resUserList.map(item => ({
…item, //保持原数组不变添加ischecked属性
ischecked: item.SNO in obj; //如果obj对象中存在item.SNO 则为true 反之为false
}))