zoukankan      html  css  js  c++  java
  • 浅谈JavaScript对象数组根据某属性sort升降序排序

    1、自定义一个比较器,其参数为待排序的属性。

    2、将带参数的比较器传入sort()。

    var data = [
    	{name: "Bruce", age: 23, id: 16, score: 80},
    	{name: "Alice", age: 24, id: 12, score: 90},
    	{name: "David", age: 21, id: 11, score: 70},
    	{name: "Cindy", age: 22, id: 10, score: 100},
    ];
    data.sort(compareUp("age"));
    data.sort(compareDown("age"));
    function compareUp(propertyName) { // 升序排序
        if ((typeof data[0][propertyName]) != "number") { // 属性值为非数字
    		return function(object1, object2) {
    			var value1 = object1[propertyName];
    			var value2 = object2[propertyName];
    			return value1.localeCompare(value2);
    		}
    	}
    	else {
    		return function(object1, object2) { // 属性值为数字
    			var value1 = object1[propertyName];
    			var value2 = object2[propertyName];
    			return value1 - value2;
    		}
    	}
    }
    function compareDown(propertyName) { // 降序排序
        if ((typeof data[0][propertyName]) != "number") { // 属性值为非数字
    		return function(object1, object2) {
    			var value1 = object1[propertyName];
    			var value2 = object2[propertyName];
    			return value2.localeCompare(value1);
    		}
    	}
    	else {
    		return function(object1, object2) { // 属性值为数字
    			var value1 = object1[propertyName];
    			var value2 = object2[propertyName];
    			return value2 - value1;
    		}
    	}
    }
    

      

  • 相关阅读:
    统计学习及监督学习概论(2)
    推荐系统(1)
    统计学习及监督学习概论(1)
    JavaScript学习08 Cookie对象
    JavaScript学习07 内置对象
    JavaScript学习06 JS事件对象
    JavaScript学习05 定时器
    JavaScript学习04 对象
    JavaScript学习03 JS函数
    JavaScript学习02 基础语法
  • 原文地址:https://www.cnblogs.com/mmykdbc/p/10430408.html
Copyright © 2011-2022 走看看