Menapis tatasusunan objek berdasarkan sifat: panduan
P粉087951442
P粉087951442 2023-10-09 16:41:54
0
2
776

Saya mempunyai susunan JavaScript objek rumah hartanah berikut:

var json = {
    'homes': [{
            "home_id": "1",
            "price": "925",
            "sqft": "1100",
            "num_of_beds": "2",
            "num_of_baths": "2.0",
        }, {
            "home_id": "2",
            "price": "1425",
            "sqft": "1900",
            "num_of_beds": "4",
            "num_of_baths": "2.5",
        },
        // ... (more homes) ...     
    ]
}

var xmlhttp = eval('(' + json + ')');
homes = xmlhttp.homes;

Apa yang saya mahu lakukan ialah dapat melakukan penapisan pada objek untuk mengembalikan subset objek "rumah".

Sebagai contoh, saya ingin dapat menapis berdasarkan: pricesqftnum_of_bedsnum_of_baths.

Bagaimana untuk melakukan sesuatu seperti pseudokod berikut dalam JavaScript:

var newArray = homes.filter(
    price <= 1000 & 
    sqft >= 500 & 
    num_of_beds >=2 & 
    num_of_baths >= 2.5 );

Sila ambil perhatian bahawa sintaks tidak semestinya sama seperti di atas. Ini hanya contoh.

P粉087951442
P粉087951442

membalas semua(2)
P粉366946380

Saya terkejut tiada siapa yang menghantar balasan satu baris:

const filteredHomes = json.homes.filter(x => x.price = 500 && x.num_of_beds >=2 && x.num_of_baths >= 2.5);

...sekadar untuk memudahkan anda membaca:

const filteredHomes = json.homes.filter( x => 
  x.price = 500 && 
  x.num_of_beds >=2 && 
  x.num_of_baths >= 2.5
);
P粉315680565

Anda boleh menggunakan kaedah 数组.prototype.filter:

var newArray = homes.filter(function (el) {
  return el.price = 500 &&
         el.num_of_beds >=2 &&
         el.num_of_baths >= 2.5;
});

Contoh:

var obj = {
    'homes': [{
            "home_id": "1",
            "price": "925",
            "sqft": "1100",
            "num_of_beds": "2",
            "num_of_baths": "2.0",
        }, {
            "home_id": "2",
            "price": "1425",
            "sqft": "1900",
            "num_of_beds": "4",
            "num_of_baths": "2.5",
        },
        // ... (more homes) ...     
    ]
};
// (Note that because `price` and such are given as strings in your object,
// the below relies on the fact that = with a string and number
// will coerce the string to a number before comparing.)
var newArray = obj.homes.filter(function (el) {
  return el.price = 500 &&
         el.num_of_beds >= 2 &&
         el.num_of_baths >= 1.5; // Changed this so a home would match
});
console.log(newArray);
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan