我们都知道在react中,key是用来追踪列表中哪些元素被修改、删除或者被添加的辅助共识并且<li>不加key就会报错,那么在vue中也是这样吗?
在diff算法(详解vue的diff算法)中,key可以管理可复用的元素,减少不必要的元素的重新渲染,也要让必要的元素能够重新渲染。
references:
《实战vue》梁灏
vue总是尽可能高效的渲染元素而不是从头渲染,这也是diff算法的精髓。但是有些情况下并不是符合需求的,譬如:
你允许用户在不同的登录方式之间切换
<template>
<div class="test">
<div v-if="loginType === 'username'">
<label>Username:</label>
<input type="text" placeholder="Enter your username"/>
</div>
<div v-else>
<label>Email:</label>
<input type="text" placeholder="Enter your email address"/>
</div>
<button type="button" @click="handleToggleClick">切换输入类型</button>
</div>
</template>
<script type="text/javascript">
export default{
data(){
return{
loginType:'username'
}
},
methods:{
handleToggleClick(){
this.loginType = this.loginType ==='username'?'Email':'username' ;
}
}
}
</script>
<style type="text/css">
</style>
那么在上面的代码中切换loginType将不会清除用户已经输入的内容。因为两个模板使用了相同的元素,仅仅是
替换了它的 placeholder。
如下图:
切换前
切换后
这样并不符合实际需求,所以Vue
为你提供了一种方式来表达这两个元素是完全独立的,不要复用它们
。只需添加
一个具有唯一值的 key 属性
即可:
<template>
<div class="test">
<div v-if="loginType === 'username'">
<label>Username:</label>
<input type="text" placeholder="Enter your username"key="username-input"/>
</div>
<div v-else>
<label>Email:</label>
<input type="text" placeholder="Enter your email address" key="email-input"/>
</div>
<button type="button" @click="handleToggleClick">切换输入类型</button>
</div>
</template>
<script type="text/javascript">
export default{
data(){
return{
loginType:'username'
}
},
methods:{
handleToggleClick(){
this.loginType = this.loginType ==='username'?'Email':'username' ;
}
}
}
</script>
<style type="text/css">
</style>
这样就可以啦:
切换前
切换后