Szybkie pytanie. Co się stanie, jeśli masz dwie tablice obiektów i chcesz "wyrównać" te tablice obiektów, abyś mógł upewnić się, że obiekty każdej z tablic są w takiej samej kolejności, jak inne macierze? A co, jeśli nie wiesz, jakie klucze i wartości zawiera każdy z obiektów znajdujących się wewnątrz tablic ... O wiele mniej, w jakiej kolejności się znajdują?
Potrzebujesz "WildCard Expression" dla swoich [].filter
, [].map
itd. Jak uzyskać wyrażenie wieloznaczne?
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);
}));
Można również korzystać z tej funkcji w ciągu iteracji dla każdego obiektu w celu stworzenia lepszego zbiorowej ekspresji dla wszystkich kluczy w każdym z obiektów, a następnie filtrować swoją tablicę w ten sposób.
To jest mały fragment z API Juxtapose, który mam prawie ukończony, który to robi, równość obiektów z wyjątkami, jedności obiektów i kondensacji tablic. Jeśli są to rzeczy, które potrzebujesz lub chcesz dla swojego projektu, skomentuj, a ja sprawię, że lib będzie dostępny wcześniej niż później.
Mam nadzieję, że to pomoże! Szczęśliwe kodowanie :)
Przez poszukiwaniu masz na myśli filtr? – joragupra