合并数组
let ary1 = ['A1', 'A2', 'B1', 'B2', 'C1', 'C2', 'D1', 'D2'];
let ary2 = ['A', 'B', 'C', 'D'];
// 使得合并后数组为=> ary3= ['A1','A2','A','B1','B2','B','C1','C2','C','D1','D2','D'];
方法一:concat() 合并数组Map()遍历数组Sort()数组排序localeCompare()数组升序
ary2 = ary2.map(item => { return item + '3' })
console.log(ary2)
let ary3 = ary1.concat(ary2).sort((a, b) => a.localeCompare(b)).map(item => {
return item.replace(/3/g, '')
})
console.log(ary3)
注:
- 使用map()方法遍历ary2数组给每一项添加数字3
- 使用concat()方法合并ary1和ary2
- 利用sort()和localeCompare()对合并后的数组排序
- 利用map()方法将排序后的新数组遍历并且利用replace(/3/g,’’)将数字3替换为空
方法二
let n = 0
for (let i = 0; i < ary2.length; i++) {
let item2 = ary2[i]
for (let k = 0; k < ary1.length; k++) {
let item1 = ary1[k]
if (item1.includes(item2)) {
n = k //如果包含就记录下当前这一项的索引位置(后面还有包含的会重新记录这个值)
}
}
ary1.splice(n + 1, 0, item2) //把当前item2这一项插入到ary1中n的后面
}
console.log(ary1)
ES6 拓展运算符合并数组
let arrES6 = [...arr1, ...arr2];
console.log(arrES6);