• vue循环语句v-for中元素绑定值问题


    vue3跟vue2相比,有许多的变化。变得比较古怪。比如vue的王牌,页面元素与值双向绑定,所谓MVVM模式。在vue3中,要使用ref或reactive来处理,所谓响应式数据。这个响应式数据,就是在页面运行过程中,会与用户或程序交互,随之变化。如果元素对应的值,只是一次性指定,之后亘古不变,就不算响应式数据。

    响应式数据,在vue3中咋处理呢?类似这样:

    <template>
      <div>
        <a-checkable-tag v-model:checked="checked1" @change="handleChange">Tag1a-checkable-tag>
        <a-checkable-tag v-model:checked="checked2" @change="handleChange">Tag2a-checkable-tag>
        <a-checkable-tag v-model:checked="checked3" @change="handleChange">Tag3a-checkable-tag>
      div>
    template>
    <script>
    import { defineComponent, ref } from 'vue';
    export default defineComponent({
      setup() {
        // or use watch
        const handleChange = checked => {
          console.log(checked);
        };
    
        return {
          handleChange,
          checked1: ref(false),
          checked2: ref(false),
          checked3: ref(false),
        };
      },
    
    });
    script>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26

    以上是antd design vue里的示例代码
    https://antdv.com/components/tag#components-tag-demo-status

    效果就是点击标签,选中;再次点击,取消选中。
    在这里插入图片描述
    这个例子中,使用了ref。是因为绑定变量数量固定,可以预先声明。但如果数量未知、可变呢?

    那应该使用reactive。reactive处理的对象是json,绑定变量可作为该json的一个元素。

    <template>
      <div>
        <a-checkable-tag
          v-for="(tag, i) in tags"
          :key="tag"
          v-model:checked="checkeds[i]"
          @change="handleChange"
          >{{ tag }}a-checkable-tag
        >
      div>
    template>
    
    <script>
    import { defineComponent, onMounted, reactive, toRefs } from "vue";
    export default defineComponent({
      setup() {
        // or use watch
        const handleChange = (checked) => {
          console.log(checked);
        };
          
        const state = reactive({
          tags: [],
          checkeds: [],
        });
    
        onMounted(() => {
          state.tags = ["tag1", "tag2", "tag3", "tag4"];
          state.checkeds = [false, false, false, false];
        });
    
        return {
          ...toRefs(state),
          handleChange,
        };
      },
    });
    script>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38

    总结:
    响应式数据,就是可与用户或程序交互的数据。vue中,声明响应式数据,可以使用ref和reactive。二者的区别在于,ref用于指定的单个变量,reactive用于复合变量。

    参考文章:
    https://stackoverflow.com/questions/71414977/refs-inside-v-for-loop-for-vue-v3-2-25-or-above

  • 相关阅读:
    索引的创建与设计原则(2)(适合创建索引情况 )
    全球二氧化碳排放数据1deg产品(ODIAC)数据
    农林种植类VR虚拟仿真实验教学整体解决方案
    mysql操作 sql语句中的完整性约束有哪些,主键约束、外键约束、引用完整性约束,主键外键、唯一性
    最小安装CentOS7后安装Git2.37.2 220828记录
    领域驱动模型设计与微服务架构落地-从项目去剖析领域驱动
    通过访问URL地址,5分钟内渗透你的网站!很刑很可拷!
    人工智能知识全面讲解:自然语言处理概述
    【深度学习】Yolov8 区域计数
    剑指JUC原理-16.读写锁
  • 原文地址:https://blog.csdn.net/leftfist/article/details/126308744