estpzit 2022-04-19 10:41 采纳率: 80%
浏览 194
已结题

vue中的标签中的key属性

问题遇到的现象和发生背景

下方代码,为什么用key?

<router-link key="collapse"> 
问题相关代码,请勿粘贴截图
<template>
  <div class="sidebar-logo-container" :class="{'collapse':collapse}">
    <transition name="sidebarLogoFade">
      <router-link key="collapse" class="sidebar-logo-link" to="/">
        <img src="@/assets/common/logo.png" class="sidebar-logo">
      </router-link>
    </transition>
  </div>
</template>
...
props: {
  collapse: {
    type: Boolean,
    required: true
  }
}


运行结果及报错内容
我的解答思路和尝试过的方法
我想要达到的结果
  • 写回答

2条回答 默认 最新

  • 雾里桃花 2022-04-19 11:15
    关注

    vue中的key属性是为了更为快速的建立虚拟dom所准备的,一般使用在for循环中,key也可以用来表明当前节点的唯一身份,尤其是像v-for这种循环出来的列表,节点几乎都是一模一样的,这时候为每个节点添加key属性 可以使虚拟dom更为清晰的分辨出每个节点的身份
    key属性也可以用在一些其他的地方,像vue中的router-view,如果你在router-view包裹了transition 节点,这是就要为router-view动态的添加一个key属性,用于表示当前的url已经变更,vue检测到了key属性的变化就会重新执行一次transition动画,否则如果不添加key属性,vue检测不到url的变更,动画效果就只会在初始时执行一次

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月27日
  • 已采纳回答 4月19日
  • 创建了问题 4月19日

悬赏问题

  • ¥15 fastreport怎么判断当前页数
  • ¥15 Kylin-Desktop-V10-GFB-Release-JICAI_02- 2207-Build14-ARM64.iso有没有这个版本的系统啊
  • ¥15 能不能通过蓝牙将传感器数据传送到手机上
  • ¥20 100元python和数据科学实验项目
  • ¥15 根据时间在调用出列表
  • ¥15 R 包chipseeker 安装失败
  • ¥15 Veeam Backup & Replication 9.5 还原问题
  • ¥15 vue-print-nb
  • ¥15 winfrom的datagridview下拉框变成了黑色,渲染不成功
  • ¥20 利用ntfy实现短信推送