程序员社区

登录切换的小案例

用到了v-if和v-else指令

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>Title</title>
</head>
<body>
<div id="app">
  <span v-if="isUser">
    <label for="username">用户账号</label>
    <input type="text" 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>

有个小问题:
如果我们在有输入内容的情况下,切换了类型,我们发现文字依然显示之前输入的内容
但是,我们应该已经切换到另一个input元素中了,在另一个input元素中,我们并没有输入内容
为什么?
这是因为Vue在进行DOM渲染的时候,处于性能考虑,会尽可能地复用已经存在的元素,而不是重新创建新的元素

解决方案:
如果我们不希望Vue内部出现类似重复利用的问题,可以给对应的input添加key,并且我们需要保证key的不同
这里的key起到一个标识的作用

赞(0) 打赏
未经允许不得转载:IDEA激活码 » 登录切换的小案例

一个分享Java & Python知识的社区