美文网首页Web
input复用问题(利用key避免复用)

input复用问题(利用key避免复用)

作者: 瑟闻风倾 | 来源:发表于2020-07-08 13:24 被阅读0次
  • 问题:在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>

相关文章

网友评论

    本文标题:input复用问题(利用key避免复用)

    本文链接:https://www.haomeiwen.com/subject/tktccktx.html