Vue——切换登录方式案例小问题(input复用)——2020.11.17

一丶案例链接

Vue切换登录方式案例

二丶案例小问题

(一)小问题:

  • 如果我们在有输入内容的情况下,切换了类型,我们会发现文字一仍然显示之前的输入的内容
  • 但是按道理讲,我们应该切换到另一个input的元素中
  • 在另一个input元素中,我们并没有输入内容
  • 为什么会出现这个问题呢?

(二)问题解答:

  • 这是因为Vue在进行DOM渲染时,出于性能考虑,会尽可能的复用已经存在的元素,而不是重新创建新的元素
  • 在案例中,Vue内部会发现原来的input元素不再使用,直接作为else中input来使用

(三)解决方案:

  • 如果我们不考虑Vue出现类似重复利用的问题,可以给对应的input添加key
  • 并且保证key不相同
<div id="app">
  <span v-if="isUser">
    <label for="username">用户账号</label>
    <input type="text" id="username" placeholder="用户账号" key="username">
  </span>
  <span v-else>
    <label for="email">用户邮箱</label>
    <input type="text" id="email" placeholder="用户邮箱" key="email">
  </span>
  <button @click="isUserClick()">切换登录方式</button>
</div>
——千淘万漉虽辛苦,吹尽狂沙始到金——
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Blockchain_KT

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值