ホームページ  >  記事  >  ウェブフロントエンド  >  JS を使用して json オブジェクト配列をオブジェクトのプロパティで並べ替える方法

JS を使用して json オブジェクト配列をオブジェクトのプロパティで並べ替える方法

php中世界最好的语言
php中世界最好的语言オリジナル
2018-05-28 15:33:591410ブラウズ

今回は、JS を使用してオブジェクトのプロパティで json オブジェクト配列を並べ替える方法と、JS を使用してオブジェクトのプロパティで json オブジェクト配列を並べ替えるための notes について説明します。実際のケースを見てみましょう。

実際の作業では、バックグラウンドで返された配列に json データが i 個あり、json 内の特定の項目に従って配列を並べ替える必要がある、というような問題がよく発生します。

たとえば、返されるデータ構造は次のようになります:

{
  result:[
   {id:1,name:'中国银行'},
   {id:3,name:'北京银行'},
   {id:2,name:'河北银行'},
   {id:10,name:'保定银行'},
   {id:7,name:'涞水银行'}
  ]
}

次に、ビジネスニーズに応じて ID のサイズに従って並べ替え、ID の小さい JSON の順序で配列の順序を並べ替える必要があります。 IDが大きいjson

jsに追加 並べ替え方法:

こちらJavaScriptを使用 sort()メソッド、最初にsort方法を説明しますsort() 方法,首先解释下这个sort的方法

语法:arrayObject.sort(sortby)

sortby:可选,规定排序顺序。必须是函数。

如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。

如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:

若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
若 a 等于 b,则返回 0。
若 a 大于 b,则返回一个大于 0 的值。

下面开始使用sort(sortby)

構文: arrayObject.sort(sortby)<p style="text-align: left;"></p> <span style="color: #0000ff">sortby</span>: オプションで、並べ替え順序を指定します。関数である必要があります。 <p style="text-align: left;"></p>このメソッドがパラメータなしで呼び出された場合、配列内の要素はアルファベット順、より正確には文字エンコード順に並べ替えられます。これを実現するには、まず配列の要素を比較のために (必要に応じて) 文字列に変換する必要があります。 <p style="text-align: left;"><img src="https://img.php.cn/upload/article/000/061/021/07b33d344d7abff59aa519d94721c202-0.png" alt="">他の基準で並べ替えたい場合は、2 つの値を比較し、2 つの値の相対的な順序を示す数値を返す比較関数を提供する必要があります。比較関数には 2 つのパラメーター a と b が必要で、その戻り値は次のとおりです: </p> <p> a が b より小さい場合、a はソートされた配列内で b より前に表示され、0 より小さい値を返します。 </p> a が b に等しい場合、0 を返します。 <p> a が b より大きい場合、0 より大きい値を返します。 </p> <p> <code>sort(sortby) を使用してこの並べ替えを実行し、コンソールに出力してみましょう:
function sortId(a,b){
  return a.id-b.id
}
result.sort(sortId);
console.log(result);
完全なテスト サンプル コード:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>www.jb51.net json数组排序</title>
</head>
<body>
<script>
var result = [
   {id:1,name:'中国银行'},
   {id:3,name:'北京银行'},
   {id:2,name:'河北银行'},
   {id:10,name:'保定银行'},
   {id:7,name:'涞水银行'}
  ]
function sortId(a,b){
  return a.id-b.id
}
result.sort(sortId);
console.log(result);
</script>
</body>
</html>
次に、コンソールを確認して、並べ替えが成功したことを確認してください:


この記事の事例を読んだ後は、この方法を習得したと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。

推奨書籍:

vuex の入門教育手順の詳細な説明🎜🎜🎜🎜🎜 vuex の高度な使用方法🎜🎜🎜🎜🎜 vue-admin-template を使用した最適化手順の詳細な説明🎜🎜🎜

以上がJS を使用して json オブジェクト配列をオブジェクトのプロパティで並べ替える方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。