私はオブジェクトの配列を持っています:
var array = [(id, name, value),(id, name, value)]; //and so on
属性名(array[i][1])
の昇順で配列をソートするにはどうすればよいですか?
私はこれをやろうとしました:array[i][1].sort()
、しかしそれはうまくいきません。
私を助けてください!
編集:配列は3つ以上のオブジェクトを含むことができます!それは何百も含むことができます。
編集:「重複した」質問の2年前に質問されたときに、なぜこの質問が重複としてマークされているのですか
//This will sort your array
function SortByName(a, b){
var aName = a.name.toLowerCase();
var bName = b.name.toLowerCase();
return ((aName < bName) ? -1 : ((aName > bName) ? 1 : 0));
}
array.sort(SortByName);
var array = [[1, "grape", 42], [2, "fruit", 9]];
array.sort(function(a, b)
{
// a and b will here be two objects from the array
// thus a[1] and b[1] will equal the names
// if they are equal, return 0 (no sorting)
if (a[1] == b[1]) { return 0; }
if (a[1] > b[1])
{
// if a should come after b, return 1
return 1;
}
else
{
// if b should come after a, return -1
return -1;
}
});
sort
関数は追加の引数、つまり2つの引数を取る関数を取ります。この関数は、2つの引数のどちらがソートの最初に来るかに応じて、-1
、0
または1
を返す必要があります。 詳細 。
多次元配列の構文エラーも修正しました。
//objects
var array = [{id:'12', name:'Smith', value:1},{id:'13', name:'Jones', value:2}];
array.sort(function(a, b){
var a1= a.name.toLower(), b1= b.name.toLower();
if(a1== b1) return 0;
return a1> b1? 1: -1;
});
//arrays
var array =[ ['12', ,'Smith',1],['13', 'Jones',2]];
array.sort(function(a, b){
var a1= a[1], b1= b[1];
if(a1== b1) return 0;
return a1> b1? 1: -1;
});
data.sort(function(a,b)
{
return a.val - b.val;
});
sort method には、カスタム比較関数を渡すためのオプションの引数が含まれています。
配列の配列が欲しいと仮定します。
var arr = [[3, "Mike", 20],[5, "Alex", 15]];
function compareName(a, b)
{
if (a[1] < b[1]) return -1;
if (a[1] > b[1]) return 1;
return 0;
}
arr.sort(compareName);
それ以外の場合は、オブジェクトの配列が必要な場合は、次のようにします。
function compareName(a, b)
{
if (a.name < b.name) return -1;
if (a.name > b.name) return 1;
return 0;
}
本当の多次元配列を作成する代わりに、(ほとんど)JavaScriptオブジェクトの配列を作成したようです。このように配列を定義してみてください - >
var array = [ [id,name,value], [id,name,value] ]
うまくいけば、それが役立ちます!