var as = [1,2,11,3434, 3,4545 ,33,55,0];
as.sort(); //この並べ替えは辞書の並べ替えに基づいています
//数値に基づいてカスタマイズされた並べ替え
function sortByNum(a,b){
return parseInt(a) - parseInt(b);
}
as.sort(sortByNum);
//オブジェクトごとに並べ替えます
//人オブジェクトを定義します
関数 人(名前.年齢){
this.name=name;
this.age=年齢;
}
var p1 = 新しい人("zhang1",11);
var p2 =新しい人( "zhang2",1);
var p3 = 新しい人("zhang3",18);
var p4 = 新しい人("zhang4",13);
var ps = [p1 ,p2, p3,p4];
function sortByName(obj1,obj2){
if(obj1.name>obj2.name){return 1}
else if(obj1.name==obj2.name ){return 0}
else{return -1}
}
function sortByAge(obj1,obj2){
return obj1.age - obj2.age;
}
ps。 sort(sortByName ) // 名前で並べ替え
ps.sort(sortByAge) // 年齢で並べ替え
上記の並べ替えによって生じる問題は、オブジェクトに多くの属性があると仮定すると、プログラムにはいくつの属性が必要ですか? 並べ替えルールを個別に設定します。したがって、次のメソッドがあります:
function sortByProperty (proName) {
var sortFun = function(obj1,obj2){
if(obj1[proName]>obj2[proName]) {return 1}
else if(obj1[proName]==obj2) [proName] ) {return 0}
else {return -1}
}
return sortFun;
}