js数组中对象去重方法
方法一:
采用对象访问属性的方法,判断属性值是否存在,如果不存在就添加。
1 var arr = [{
2 key: '01',
3 value: '乐乐'
4 }, {
5 key: '02',
6 value: '博博'
7 }, {
8 key: '03',
9 value: '淘淘'
10 },{
11 key: '04',
12 value: '哈哈'
13 },{
14 key: '01',
15 value: '乐乐'
16 }];
17
18
19 // 方法1:利用对象访问属性的方法,判断对象中是否存在key //判断是否在对象中有当前该值
20 var result = [];
21 var obj = {};
22 for(var i =0; i<arr.length; i++){
23 if(!obj[arr[i].key]){
24 result.push(arr[i]);
25 obj[arr[i].key] = true;
26 }
27 }
28 console.log(result); // [{key: "01", value: "乐乐"},{key: "02", value: "博博"},{key: "03", value: "淘淘"},{key: "04", value: "哈哈"}]
方法二:
采用数组中的reduce方法,遍历数组,也是通过对象访问属性的方法
1 var arr = [{
2 key: '01',
3 value: '乐乐'
4 }, {
5 key: '02',
6 value: '博博'
7 }, {
8 key: '03',
9 value: '淘淘'
10 },{
11 key: '04',
12 value: '哈哈'
13 },{
14 key: '01',
15 value: '乐乐'
16 }];
// 方法2:利用reduce方法遍历数组,reduce第一个参数是遍历需要执行的函数,第二个参数是item的初始值
var obj = {};
arr = arr.reduce(function(item, next) {
obj[next.key] ? '' : obj[next.key] = true && item.push(next);
return item;
}, []);
console.log(arr); // [{key: "01", value: "乐乐"},{key: "02", value: "博博"},{key: "03", value: "淘淘"},{key: "04", value: "哈哈"}]
js冒泡排序
let list = [12,62,583,9,3,51,512,321]
for(var j=0;j<list.length-1;j++){
//第一遍循环是遍历每个数值
for(var i = 0;i < list.length-1-j; i++){
//第二遍是要将每一个值都进行对比
if(list[i] < list[i+1]){
var temp = list[i];
list[i] = list[i+1];
list[i+1] = temp;
}
}
}
console.log(list); //[583, 512, 321, 62, 51, 12, 9, 3]