Vue全选多个选择框
可以使用 v-model 来绑定一个布尔类型的变量来实现全选多个选择框的功能。
具体步骤
如下:
- 在
data中定义一个数组,用来存储所有需要选择的项的状态。 - 在模板中使用 
v-for指令循环渲染每个选择框,并将每个选择框的状态绑定到数组中对应的项上。 - 在模板中添加一个全选复选框,将其状态绑定到一个布尔类型的变量上。
 - 使用 
watch监听全选复选框的状态变化,当全选复选框的状态改变时,遍历数组中的每一项,将其状态设置为全选复选框的状态即可。 
示例代码
<template>
  <div>
    <input type="checkbox" v-model="selectAll"> 全选
    <div v-for="(item, index) in items" :key="index">
      <input type="checkbox" v-model="item.checked"> {{ item.label }}
    </div>
  </div>
</template>
<script>
export default {
  data() {
    return {
      selectAll: false,
      items: [
        { label: '选项1', checked: false },
        { label: '选项2', checked: false },
        { label: '选项3', checked: false },
      ],
    };
  },
  watch: {
    selectAll(val) {
      this.items.forEach(item => {
        item.checked = val;
      });
    },
  },
};
</script>
在上面的代码中,我们定义了一个 selectAll 变量来表示全选复选框的状态,一个 items 数组来存储所有需要选择的项的状态。
在模板中,使用 v-for 指令循环渲染每个选择框,并将每个选择框的状态绑定到数组中对应的项上。同时,还添加了一个全选复选框,并将其状态绑定到 selectAll 变量上。
在 watch 中,监听 selectAll 变量的变化,当它的状态改变时,遍历 items 数组中的每一项,将其状态设置为 selectAll 的状态即可实现全选功能。
结果展示


总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
来源链接:https://www.jb51.net/javascript/335013m4r.htm
© 版权声明
本站所有资源来自于网络,仅供学习与参考,请勿用于商业用途,否则产生的一切后果将由您(转载者)自己承担!
如有侵犯您的版权,请及时联系3500663466#qq.com(#换@),我们将第一时间删除本站数据。
如有侵犯您的版权,请及时联系3500663466#qq.com(#换@),我们将第一时间删除本站数据。
THE END
    














暂无评论内容