Vue19-key的原理

一、v-for中key的作用

给节点进行一个标识,类似于身份证号。

1-1、需求1:

点击按钮,在<li>的最前面添加一个老刘的信息

html 复制代码
<body>

    <div id="root">
        <h1>人员信息</h1>
        <button @click.once="add">点击添加老王</button>
        <ul>
            <li v-for="(p, index) in persons" ::key="index">
                {{p.name}}-{{p.age}}
                <input type="text">
            </li>
           
        </ul>
        
    </div>

    <script>
        new Vue({
            el:'#root',
            data:{
                persons:[
                    {id:'001', name:'张三', age: 18},
                    {id:'002', name:'李四', age: 20},
                    {id:'003', name:'王五', age: 10}
                ]
            },
            methods: {
                add(){
                    const p = {id:'004', name:'老王', age: 40};
                    // 将数据往数组前面加
                    this.persons.unshift(p);
                }
            },
        })
    </script>
    
</body>

因为,key被vue内部在用。

1-2、key="index"的问题:

1、效率不高

2、文本框错乱

1-3、遍历列表的时候key的作用

用户操作的都是真实的DOM。

虚拟DOM做对比算法的时候,拿的是两边的key做的对比。
若是将老王加在王五的后面,则不存在该问题。

所以,当对数据进行了破坏顺序的操作时,key="index"有问题!

张三、李四、王五都是新生成的,不是从左边已经生成的真实DOM中复用的,所以效率低

1-4、解决方式:key="p.id"

1-5、v-for遍历没有key

当v-for遍历没有key的时候,vue自动将遍历时候的索引值(index)作为key了。

二、小结

相关推荐
90后的晨仔5 分钟前
Vue 内置组件全解析:提升开发效率的五大神器
前端·vue.js
我胡为喜呀8 分钟前
Vue3 中的 watch 和 watchEffect:如何优雅地监听数据变化
前端·javascript·vue.js
我登哥MVP31 分钟前
Ajax 详解
java·前端·ajax·javaweb
非凡ghost1 小时前
Typora(跨平台MarkDown编辑器) v1.12.2 中文绿色版
前端·windows·智能手机·编辑器·软件需求
馨谙1 小时前
/dev/null 是什么,有什么用途?
前端·chrome
JamSlade2 小时前
流式响应 sse 系统全流程 react + fastapi为例子
前端·react.js·fastapi
徐同保2 小时前
react useState ts定义类型
前端·react.js·前端框架
liangshanbo12152 小时前
React 19 vs React 18全面对比
前端·javascript·react.js
望获linux2 小时前
【实时Linux实战系列】Linux 内核的实时组调度(Real-Time Group Scheduling)
java·linux·服务器·前端·数据库·人工智能·深度学习
Never_Satisfied3 小时前
在 JavaScript 中,删除数组中内容为xxx的元素
java·前端·javascript