Vue中key的具体使用

 更新时间:2024年06月12日 09:34:14   作者:ruleslol  
在vue中,key是dom对象的标识,本文主要介绍了Vue中key的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、v-for中key的作用

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

1-1、需求1:

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

<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了。

二、小结

到此这篇关于Vue中key的具体使用的文章就介绍到这了,更多相关Vue key内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vuex 在Vue 组件中获得Vuex 状态state的方法

    Vuex 在Vue 组件中获得Vuex 状态state的方法

    今天小编就为大家分享一篇Vuex 在Vue 组件中获得Vuex 状态state的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-08-08
  • vue实现图片按比例缩放问题操作

    vue实现图片按比例缩放问题操作

    这篇文章主要介绍了vue实现图片按比例缩放问题操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • vue组件间的参数传递实例详解

    vue组件间的参数传递实例详解

    这篇文章主要介绍了vue组件间的参数传递 ,需要的朋友可以参考下
    2019-04-04
  • 详解win7 cmd执行vue不是内部命令的解决方法

    详解win7 cmd执行vue不是内部命令的解决方法

    这篇文章主要介绍了详解win7 cmd执行vue不是内部命令的解决方法的相关资料,这里提供了解决问题的详细步骤,具有一定的参考价值,需要的朋友可以参考下
    2017-07-07
  • vue实现打印功能的示例代码

    vue实现打印功能的示例代码

    这篇文章主要为大家详细介绍了如何通过vue实现打印功能,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-12-12
  • vue中echarts关系图动态增删节点以及连线方式

    vue中echarts关系图动态增删节点以及连线方式

    这篇文章主要介绍了vue中echarts关系图动态增删节点以及连线方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • 使用elementUI的表格table给列添加样式

    使用elementUI的表格table给列添加样式

    这篇文章主要介绍了使用elementUI的表格table给列添加样式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • 详解uniapp的生命周期

    详解uniapp的生命周期

    这篇文章主要介绍了uniapp的生命周期,应用生命周期是指应用程序从启动到关闭的整个过程,包括应用程序的启动、前后台切换、退出等,需要的朋友可以参考下
    2023-04-04
  • 关于在vue中实现过渡动画的代码示例

    关于在vue中实现过渡动画的代码示例

    Vue是一款流行的前端框架,支持过渡动画的实现是其中的一项重要特性,在Vue中,使用过渡动画可以为用户提供更加友好的用户体验,下面我将为大家介绍一下子如何在Vue中实现过渡动画,需要的朋友可以参考下
    2023-06-06
  • Vue.js实战之使用Vuex + axios发送请求详解

    Vue.js实战之使用Vuex + axios发送请求详解

    这篇文章主要给大家介绍了关于Vue.js使用Vuex与axios发送请求的相关资料,文中介绍的非常详细,相信对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-04-04

最新评论