Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Javascript

ลบค่าที่ซ้ำกันออกจากอาร์เรย์ด้วยข้อมูลรูปภาพใน JavaScript


สมมติว่าเรามีข้อมูลบางอย่างเกี่ยวกับภาพบางภาพในอาร์เรย์เช่นนี้ −

const arr = [{
   'image': "jv2bcutaxrms4i_img.png",
   'gallery_image': true
},
{
   'image': "abs.png",
   'gallery_image': true
},
{
   'image': "acd.png",
   'gallery_image': false
},
{
   'image': "jv2bcutaxrms4i_img.png",
   'gallery_image': true
},
{
   'image': "abs.png",
   'gallery_image': true
},
{
   'image': "acd.png",
   'gallery_image': false
}];

เราจำเป็นต้องเขียนฟังก์ชัน JavaScript ที่รับอาร์เรย์ดังกล่าว

ฟังก์ชันของเราควรลบอ็อบเจ็กต์ออกจากอาร์เรย์ที่มีค่าซ้ำกันสำหรับคุณสมบัติ 'image'

ตัวอย่าง

รหัสสำหรับสิ่งนี้จะเป็น −

const arr = [{
   'image': "jv2bcutaxrms4i_img.png",
   'gallery_image': true
},
{
   'image': "abs.png",
   'gallery_image': true
},
{
   'image': "acd.png",
   'gallery_image': false
},
{
   'image': "jv2bcutaxrms4i_img.png",
   'gallery_image': true
},
{
   'image': "abs.png",
   'gallery_image': true
},
{
   'image': "acd.png",
   'gallery_image': false
}];
const buildUnique = (arr = []) => {
   const unique = [];
   arr.forEach(obj => {
      let found = false;
      unique.forEach(uniqueObj => {
         if(uniqueObj.image === obj.image) {
            found = true;
         };
      });
      if(!found){
         unique.push(obj);
      };
   });
   return unique;
};
console.log(buildUnique(arr));

ผลลัพธ์

และผลลัพธ์ในคอนโซลจะเป็น −

[
   { image: 'jv2bcutaxrms4i_img.png', gallery_image: true },
   { image: 'abs.png', gallery_image: true },
   { image: 'acd.png', gallery_image: false }
]