JS中根据对象中的一个字段进行排序

    let arr = [
        {name: '张三',age: 18},
        {name: '李四',age: 9},
        {name: '王五',age: 28}
    ]
    
	//定义方法
    const handle = (property) => {
        return function(a,b){
            const val1 = a[property];
            const val2 = b[property];
            return val1 - val2;
        }
    }
	
	//排序
    arr.sort(handle('age'));

方法2

var datalist = data.varList
var newArr = datalist.sort(sortDate);
// 数据按照时间排序
function sortDate(a, b) {
// time 是时间的字段 a-b 正序 b-a 倒序
return Date.parse(b.ADD_TIME) - Date.parse(a.ADD_TIME);
}

const、var、let的区别

1.const定义的变量不可以修改,而且必须初始化。

const b = 2;//正确
// const b;//错误,必须初始化 
console.log('函数外const定义b:' + b);//有输出值
// b = 5;
// console.log('函数外修改const定义b:' + b);//无法输出 

2.var定义的变量可以修改,如果不初始化会输出undefined,不会报错。

var a = 1;
// var a;//不会报错
console.log('函数外var定义a:' + a);//可以输出a=1
function change(){
a = 4;
console.log('函数内var定义a:' + a);//可以输出a=4
} 
change();
console.log('函数调用后var定义a为函数内部修改值:' + a);//可以输出a=4

3.let是块级作用域,函数内部使用let定义后,对函数外部无影响。

let c = 3;
console.log('函数外let定义c:' + c);//输出c=3
function change(){
let c = 6;
console.log('函数内let定义c:' + c);//输出c=6
} 
change();
console.log('函数调用后let定义c不受函数内部定义影响:' + c);//输出c=3

你可能感兴趣的:(笔记,js)