とても簡単な質問です。オブジェクトの配列が2つあり、これらのオブジェクト配列を「整列」させて、各配列のオブジェクトが他の配列のオブジェクトと同じ順序になっていることを確認したい場合はどうでしょうか。配列内のオブジェクトに含まれているキーと値がわからない場合はどうなりますか...ましてや、それらがどのような順序であるかはわかりません。
あなたのための「ワイルドカード表現」を必要とするので[].filter
、[].map
などがどのようにワイルドカード表現を得るのですか?
var jux = (function(){
'use strict';
function wildExp(obj){
var keysCrude = Object.keys(obj),
keysA = ('a["' + keysCrude.join('"], a["') + '"]').split(', '),
keysB = ('b["' + keysCrude.join('"], b["') + '"]').split(', '),
keys = [].concat(keysA, keysB)
.sort(function(a, b){ return a.substring(1, a.length) > b.substring(1, b.length); });
var exp = keys.join('').split(']b').join('] > b').split(']a').join('] || a');
return exp;
}
return {
sort: wildExp
};
})();
var sortKeys = {
k: 'v',
key: 'val',
n: 'p',
name: 'param'
};
var objArray = [
{
k: 'z',
key: 'g',
n: 'a',
name: 'b'
},
{
k: 'y',
key: 'h',
n: 'b',
name: 't'
},
{
k: 'x',
key: 'o',
n: 'a',
name: 'c'
}
];
var exp = jux.sort(sortKeys);
console.log('@juxSort Expression:', exp);
console.log('@juxSort:', objArray.sort(function(a, b){
return eval(exp);
}));
また、各オブジェクトの反復でこの関数を使用して、各オブジェクトのすべてのキーに対してより適切な集合式を作成し、その方法で配列をフィルター処理することもできます。
これは、私がほぼ完成したAPI Juxtaposeからの小さなスニペットであり、これを実行します。これは、オブジェクトの同等性と免除、オブジェクトの単一性、および配列の凝縮です。これらがプロジェクトに必要または必要なものである場合は、コメントしてください。ライブラリにアクセスできるようにします。
お役に立てれば!ハッピーコーディング:)