Fi首先獲取所有標籤並從initialState過濾重複標籤。將數組保存到uniqueTags中。
然後將uniqueTags與initialState名稱進行比較,以創建具有對象及其屬性標記和產品的另一個數組productTags。
const initialState = [
{id:1 ,name: 'Product A', image: 'pic-001.jpg', tags: ['nature', 'camping', 'winter', 'outdoor']},
{id:2 ,name: 'Product B', image: 'pic-002.jpg', tags: ['winter', 'hiking', 'family', 'camping', 'snow']},
{id:3 ,name: 'Product C', image: 'pic-003.jpg', tags: ['vacation', 'family', 'kids', 'river', 'lake', 'fishing']}
]
let allTags = [];
initialState.map((t)=>t.tags).forEach((a)=>a.forEach((b)=>allTags.push(b)))
let uniqueTags = allTags.filter((a,i,arr)=>arr.indexOf(a,i+1)===-1)
productTags = [];
uniqueTags.forEach((u)=>{
initialState.forEach((t)=>{
if(t.tags.includes(u))
productTags.push({'tag': u, 'product':t.name});
})
})
console.log(JSON.stringify(productTags));
/*
[
{ "tag": "nature", "product": "Product A" },
{ "tag": "outdoor", "product": "Product A" },
{ "tag": "winter", "product": "Product A" },
{ "tag": "winter", "product": "Product B" },
{ "tag": "hiking", "product": "Product B" },
{ "tag": "camping", "product": "Product A" },
{ "tag": "camping", "product": "Product B" },
{ "tag": "snow", "product": "Product B" },
{ "tag": "vacation", "product": "Product C" },
{ "tag": "family", "product": "Product B" },
{ "tag": "family", "product": "Product C" },
{ "tag": "kids", "product": "Product C" },
{ "tag": "river", "product": "Product C" },
{ "tag": "lake", "product": "Product C" },
{ "tag": "fishing", "product": "Product C" }
] */
(後來編輯)更正:
形成正確的對象,我已經改變了代碼:
const initialState = [
{id:1 ,name: 'Product A', image: 'pic-001.jpg', tags: ['nature', 'camping', 'winter', 'outdoor']},
{id:2 ,name: 'Product B', image: 'pic-002.jpg', tags: ['winter', 'hiking', 'family', 'camping', 'snow']},
{id:3 ,name: 'Product C', image: 'pic-003.jpg', tags: ['vacation', 'family', 'kids', 'river', 'lake', 'fishing']}
]
let allTags = [];
initialState.map((t)=>t.tags).forEach((a)=>a.forEach((b)=>allTags.push(b)))
let uniqueTags = allTags.filter((a,i,arr)=>!arr.includes(a,i+1))
productTags = [];
uniqueTags.forEach((u)=>{
let productName = [];
initialState.forEach((t)=>{
if(t.tags.includes(u))
productName.push(t.name);
})
productTags.push({tag:u, products:productName});
})
console.log(JSON.stringify(productTags));
/*
productTags = [
{"tag":"nature","products":["Product A"]},
{"tag":"outdoor","products":["Product A"]},
{"tag":"winter","products":["Product A","Product B"]},
{"tag":"hiking","products":["Product B"]},
{"tag":"camping","products":["Product A","Product B"]},
{"tag":"snow","products":["Product B"]},
{"tag":"vacation","products":["Product C"]},
{"tag":"family","products":["Product B","Product C"]},
{"tag":"kids","products":["Product C"]},
{"tag":"river","products":["Product C"]},
{"tag":"lake","products":["Product C"]},
{"tag":"fishing","products":["Product C"]}
]
*/
我不認爲有這樣做的任何其他方式。你將不得不遍歷整個數組,以符合與標籤匹配的條件。 –
你可以在你的過濾器函數中使用array.indexOf。 – James