Bootstrap

轻松掌握 JS 删除数组中指定的对象或者删除数组中某一项

前言

关于 JS 删除数组中指定的对象或某一项的话题,它是在实际开发中经常会遇到的问题,也是需要掌握的基本技能。在这篇文章中,我们将深入探讨如何使用 JS 来删除数组中指定的对象或者删除数组中某一项。


删除数组中指定的对象

方法一:使用 filter

这种方法使用了 vuefilter 方法,它会创建一个新的数组,其中不包含满足条件的对象。condition 是一个函数,用于判断对象是否满足条件。在这个方法中,我们遍历数组中的每个对象,如果对象满足条件,则不包含在新数组中,最后将新数组赋值给原数组。

代码实例

<template>
  <div>
    <el-select v-model="shztModel" clearable placeholder="请选择审核状态">
      <el-option v-for="item in optionsAudit" :key="item.value" :label="item.label" :value="item.value"></el-option>
    </el-select>
  </div>
</template>
<script>
export default {
  data() {
    return {
      shztModel: "",
      optionsAudit: [
        {
          value: "1",
          label: "初审通过",
        },
        {
          value: "2",
          label: "初审不通过",
        },
        {
          value: "3",
          label: "未上报",
        },
        {
          value: "4",
          label: "复审通过",
        },
        {
          value: "5",
          label: "复审不通过",
        },
      ],
    };
  },
  mounted() {
    this.optionsAudit = this.optionsAudit.filter(
      (item) => !this.condition(item)
    );
    console.log(this.optionsAudit);
  },
  methods: {
    condition(item) {
      return item.value == "2";
    },
  },
};
</script>

方法二:使用 splice 方法和 forEach

这种方法使用了 vuesplice 方法和 forEach 方法。我们遍历数组中的每个对象,如果对象满足条件,则使用 splice 方法删除该对象。splice 方法的第一个参数是要删除的对象的索引,第二个参数是要删除的对象的数量。

代码实例

<template>
  <div>
    <el-select v-model="shztModel" clearable placeholder="请选择审核状态">
      <el-option v-for="item in optionsAudit" :key="item.value" :label="item.label" :value="item.value"></el-option>
    </el-select>
  </div>
</template>
<script>
export default {
  data() {
    return {
      shztModel: "",
      optionsAudit: [
        {
          value: "1",
          label: "初审通过",
        },
        {
          value: "2",
          label: "初审不通过",
        },
        {
          value: "3",
          label: "未上报",
        },
        {
          value: "4",
          label: "复审通过",
        },
        {
          value: "5",
          label: "复审不通过",
        },
      ],
    };
  },
  mounted() {
    this.optionsAudit.forEach((item, index) => {
      if (this.condition(item)) {
        this.optionsAudit.splice(index, 1);
      }
    });
    console.log(this.optionsAudit);
  },
  methods: {
    condition(item) {
      return item.value == "2";
    },
  },
};
</script>

方法三:使用 $delete 和 forEach

这种方法使用了 vuedelete 方法和 forEach 方法。我们遍历数组中的每个对象,如果对象满足条件,则使用 delete 方法和 forEach 方法。我们遍历数组中的每个对象,如果对象满足条件,则使用 delete 方法删除该对象。$delete 方法的第一个参数是要删除的对象所在的数组,第二个参数是要删除的对象的索引。

代码实例

<template>
  <div>
    <el-select v-model="shztModel" clearable placeholder="请选择审核状态">
      <el-option v-for="item in optionsAudit" :key="item.value" :label="item.label" :value="item.value"></el-option>
    </el-select>
  </div>
</template>
<script>
export default {
  data() {
    return {
      shztModel: "",
      optionsAudit: [
        {
          value: "1",
          label: "初审通过",
        },
        {
          value: "2",
          label: "初审不通过",
        },
        {
          value: "3",
          label: "未上报",
        },
        {
          value: "4",
          label: "复审通过",
        },
        {
          value: "5",
          label: "复审不通过",
        },
      ],
    };
  },
  mounted() {
    this.optionsAudit.forEach((item, index) => {
      if (this.condition(item)) {
        this.$delete(this.optionsAudit, index);
      }
    });
    console.log(this.optionsAudit);
  },
  methods: {
    condition(item) {
      return item.value == "2";
    },
  },
};
</script>

方法四:使用 reduce

这种方法使用了 vuereduce 方法。我们遍历数组中的每个对象,如果对象不满足条件,则将其添加到一个累加器数组中。最后,将累加器数组赋值给原数组。reduce 方法的第一个参数是一个回调函数,该函数接受两个参数:累加器和当前对象。回调函数返回的值将作为下一次迭代的累加器的值。在这个方法中,我们使用一个空数组作为初始累加器的值。

代码实例

<template>
  <div>
    <el-select v-model="shztModel" clearable placeholder="请选择审核状态">
      <el-option v-for="item in optionsAudit" :key="item.value" :label="item.label" :value="item.value"></el-option>
    </el-select>
  </div>
</template>
<script>
export default {
  data() {
    return {
      shztModel: "",
      optionsAudit: [
        {
          value: "1",
          label: "初审通过",
        },
        {
          value: "2",
          label: "初审不通过",
        },
        {
          value: "3",
          label: "未上报",
        },
        {
          value: "4",
          label: "复审通过",
        },
        {
          value: "5",
          label: "复审不通过",
        },
      ],
    };
  },
  mounted() {
    this.optionsAudit = this.optionsAudit.reduce((acc, item) => {
      if (!this.condition(item)) {
        acc.push(item);
      }
      return acc;
    }, []);
    console.log(this.optionsAudit);
  },
  methods: {
    condition(item) {
      return item.value == "2";
    },
  },
};
</script>

方法五:使用 findIndex(es6) 和 splice

使用 findIndex 方法来查找数组中满足条件的对象的索引。判断对象的 value 属性值是否等于 2。如果等于,则使用 splice 方法删除它。

代码实例

<template>
  <div>
    <el-select v-model="shztModel" clearable placeholder="请选择审核状态">
      <el-option v-for="item in optionsAudit" :key="item.value" :label="item.label" :value="item.value"></el-option>
    </el-select>
  </div>
</template>
<script>
export default {
  data() {
    return {
      shztModel: "",
      optionsAudit: [
        {
          value: "1",
          label: "初审通过",
        },
        {
          value: "2",
          label: "初审不通过",
        },
        {
          value: "3",
          label: "未上报",
        },
        {
          value: "4",
          label: "复审通过",
        },
        {
          value: "5",
          label: "复审不通过",
        },
      ],
    };
  },
  mounted() {
    let index = this.optionsAudit.findIndex((item) => item.value == "2");
    if (index !== -1) {
      this.optionsAudit.splice(index, 1);
    }
    console.log(this.optionsAudit);
  },
};
</script>

实现效果

在这里插入图片描述


删除数组中指定的项

方法一:使用 filter

使用 filter 方法可以创建一个新的数组,其中包含满足条件的项。这样就可以实现删除数组中指定项的效果。
filter() 方法通过检查指定数组中符合条件的所有元素,filter() 方法不会改变原始数组。

代码实例

mounted() {
  let arrList = ["周一", "周二", "周三", "周四", "周五"];
  arrList = arrList.filter((item) => item !== "周三");
},

方法二:使用 splice

splice 方法可以直接修改原始数组,通过指定要删除的项的索引和要删除的项的数量来实现删除。

代码实例

mounted() {
  let arrList = ["周一", "周二", "周三", "周四", "周五"];
  const index = arrList.indexOf("周三");
  if (index > -1) {
    arrList.splice(index, 1);
  }
},

方法三:使用 reduce

reduce 方法可以遍历数组并返回一个累加的结果。我们可以使用 reduce 方法来创建一个新的数组,其中不包含满足条件的项。

代码实例

mounted() {
  let arrList = ["周一", "周二", "周三", "周四", "周五"];
  arrList = arrList.reduce((acc, item) => {
    if (item !== "周三") {
      acc.push(item);
    }
    return acc;
  }, []);
},

方法四:computed 属性

在这种方法中,我们可以创建一个 computed 属性,例如 filteredArray,它会根据条件过滤数组中的项,并返回一个新的数组,当数组发生变化时,computed 属性会自动更新,因此无需手动调用删除方法。只需在模板中使用 computed 属性即可获取过滤后的数组。

代码实例

computed: {
  filteredArray() {
    let arrList = ["周一", "周二", "周三", "周四", "周五"];
    return arrList.filter((item) => item !== "周三");
  },
},

方法五:逆序遍历

在这个方法中,我们使用了一个逆序的 for 循环,从数组的最后一项开始遍历,直到第一项。在每次循环中,我们判断当前项是否等于要删除的指定项,如果是,则使用 splice 方法删除该项。

逆序遍历的优点是可以避免在删除数组项时对数组索引的影响。由于我们是从最后一项开始遍历,因此删除当前项不会影响后面项的索引,保证了删除操作的准确性。

然而,需要注意的是,逆序遍历会改变数组的顺序。如果需要保持数组的顺序不变,可以使用其他方法,如前面提到的 filter 方法或 slice 方法。

总之,逆序遍历是一种实现根据条件删除数组中指定项的方法,它可以避免对数组索引的影响,但会改变数组的顺序。根据具体需求选择合适的方法来实现删除功能。

代码实例

mounted() {
  let arrList = ["周一", "周二", "周三", "周四", "周五"];
  for (let i = arrList.length - 1; i >= 0; i--) {
    if (arrList[i] === "周三") {
      arrList.splice(i, 1);
    }
  }
},

打印结果

在这里插入图片描述

;