首页 > 解决方案 > 试图弄清楚为什么该功能不起作用

问题描述

我编写了一个过滤器函数,它应该过滤对象数组并且它确实过滤了它,但是结果变量没有得到过滤后的数组。

数组示例:

hotels: [{
  photo: "/some_address/some_photo.png",
  name: "Hotel Moscow Name",
  address: "Moscow, some street, 1",
  amenities: [{
      name: 'wi-fi'
    }, {
      name: 'bar'
    }, {
      name: 'pool'
    }, {
      name: 'transfer'
    },
    {
      name: 'bath'
    }, {
      name: 'breakfast'
    }, {
      name: 'spa'
    }
  ],
  price: 3000
},
{
  photo: "/some_address/some_photo.png",
  name: "Hotel  St.Pitersberg Name",
  address: "sSt.Pitersberg, some street, 2",
  amenities: [{
      name: 'wi-fi'
    }, {
      name: 'bar'
    }, {
      name: 'fitness'
    }, {
      name: 'transfer'
    },
    {
      name: 'bath'
    }, {
      name: 'breakfast'
    }, {
      name: 'spa'
    }
  ],
  price: 4000
},
}]
changeFilterValue: function(choosenAmenity) {
    this.changeFiltersList(choosenAmenity);
    let settedList = this.settedFilters;

    this.filteredData = this.hotels.filter(function(hotel) { //массив hotels
      let amenityArray = [];
      hotel.amenities.forEach(function(amenity) {
        amenityArray.push(amenity.name);
      })
      return settedList.filter(function(elem) {
        console.log(settedList, amenityArray);
        console.log(amenityArray.includes(elem));
        return amenityArray.includes(elem);
      });
    })
    console.log(this.filteredData);

标签: javascript

解决方案


settedList.filter(...)返回一些数组,该数组始终为return settedList.filter(...).length如果要检查数组是否不为空,请尝试


推荐阅读