我们都知道在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>

这样就可以啦:

切换前

切换后

 

Logo

前往低代码交流专区

更多推荐