v-if、v-else、v-elseif

文章介绍了Vue.js中v-if和v-show指令用于条件渲染DOM元素的用法,包括它们与布尔值的关系以及v-if、v-else、v-else-if的逻辑控制。还讨论了Vue在DOM渲染时的复用策略,并给出了防止元素复用问题的解决方法——使用key属性。
摘要由CSDN通过智能技术生成

v-if用于条件判断,判断Dom元素是否显示

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>
<body>
  <div id="app">
    <h2 v-if="isFlag">isFlag为true显示这个</h2>
    <h2 v-show="isShow">isShow为true是显示这个</h2>
    <div v-if="age<18">小于18岁未成年</div>
    <div v-else-if="age<60">大于18岁小于60岁正值壮年</div>
    <div v-else="">大于60岁,暮年</div>
  </div>
  <script src="https://cdn.jsdelivr.net/npm/vue@2.6.10/dist/vue.js"></script>
  <script>
    const app = new Vue({
      el:"#app",
      data:{
        isFlag:true,
        isShow:false,
        age:66
      }
    })
  </script>
</body>
</html>
  1. 单独使用v-if,变量为布尔值,为true才渲染Dom

  2. v-show的变量也是布尔值,为true才显示内容,类似css的display

  3. v-if、v-else、v-else-if联合使用相当于if、elseif、else,但是在条件比较多的时候建议使用计算属性。

  4. v-if的demo

  5. 在登录网站是经常可以选择使用账户名或者邮箱登录的切换按钮。要求点击按钮切换登录方式。

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

    !使用v-ifv-else选择渲染指定的Dom,点击按钮对isUser变量取反。

  7. 这里需要了解一下vue底层操作,此时input输入框值被复用了。

    vue在进行DOM渲染是,处于性能考虑,会复用已经存在的元素,而不是每次都创建新的DOM元素。

    在上面demo中,Vue内部发现原来的input元素不再使用,所以直接将其映射对应虚拟DOM,用来复用。

    如果不希望出现类似复用问题,可以给对应的dom元素加上key值,并保证key不同。

    <input type="text" id="username" placeholder="请输入用户名" key="username">
    <input type="text" id="email" placeholder="请输入用户邮箱" key="email">
     

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值