问题:切换类型,文字依然显示之前的输入内容

158 阅读1分钟

原因探究:

Vue在进行DOM渲染时,出于性能考虑,会尽可能的复用已经存在的元素,而不是重新创建新的元素

(在虚拟DOM中互斥的东西不需要保存两份)

问题代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="app">
        <span v-if="isUser">
            <label for="username">账号</label>
            <input type="text" name="" id="username" placeholder="用户账号">

        </span>
        <span v-else>
            <label for="email">邮箱</label>
            <input type="text" id="email" placeholder="用户邮箱">

        </span>
        <button @click="isUser = !isUser">切换类型</button>
    </div>
    <script  src="../js/vue.js"></script>
    <script>
        const app = new Vue({
            el: '#app',
            data: {
                isUser: true
            }
        }) 
    </script>
</body>
</html> 

解决方案:

 当需要避免Vue出现类似重复利用的问题,可以为对应的input添加key

在添加时,注意key的不同

添加key后的代码:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta http-equiv="X-UA-Compatible" content="IE=edge">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <title>Document</title>
</head>
<body>
 <div id="app">
     <span v-if="isUser">
         <label for="username">账号</label>
         <input type="text" name="" id="username" placeholder="用户账号" key="username">
     </span>
     <span v-else>
         <label for="email">邮箱</label>
         <input type="text" id="email" placeholder="用户邮箱" key="email">
     </span>
     <button @click="isUser = !isUser">切换类型</button>
 </div>
 <script  src="../js/vue.js"></script>
 <script>
     const app = new Vue({
         el: '#app',
         data: {
             isUser: true
         }
     }) 
 </script>
</body>
</html>