- 问题:在input1中输入内容后,切换类型后,发现input2中显示之前input1中输入的内容
- 分析:vue底层在进行DOM渲染时,出于性能考虑,会尽可能地复用已经存在的元素,而不是重新创建新的元素
- 解决:如果我们不希望Vue出现类似重复利用的问题,可以给对应的input添加key(key值自定义,不一样即可)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Document</title>
<script type="text/javascript" src="../first/vue1026.js"></script>
</head>
<body>
<div id="app">
<span v-if="isUser">
<!-- for="username"的作用:当点击文本“用户账号”时,会聚焦到输入框 -->
<label for="username">用户账号</label>
<!-- key的作用:避免输入框复用 -->
<input type="text" id="username" placeholder="用户账号" key="1">
</span>
<span v-else>
<label for="email">用户邮箱</label>
<input type="text" id="email" placeholder="用户邮箱" key="2">
</span>
<button @click="isUser = !isUser">切换登录类型</button>
</div>
</body>
<script type="text/javascript">
var vm = new Vue({
el:"#app",
data:{
isUser :true
},
computed:{
},
methods:{
}
});
</script>
</html>
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。