zoukankan      html  css  js  c++  java
  • vue条件渲染

    1. v-if

    实例

    1. 基本使用
     <h1 v-if="ok">Yes</h1>
    
    1. 如果想切换多个元素,可以使用template元素,渲染结构不包含template元素
    <template v-if="ok">
      <h1>Title</h1>
      <p>Paragraph 1</p>
      <p>Paragraph 2</p>
    </template>
    
    1. 使用else
    <div v-if="Math.random() > 0.5">
      Now you see me
    </div>
    <div v-else>
      Now you don't
    </div>
    
    1. 使用v-else-if
    <div v-if="type === 'A'">
      A
    </div>
    <div v-else-if="type === 'B'">
      B
    </div>
    <div v-else-if="type === 'C'">
      C
    </div>
    <div v-else>
      Not A/B/C
    </div>
    
    

    2. 使用key管理可复用元素

    不使用key,当切换登陆方式时候,input框中已经输入的内容不会变,只是placeholder中内容改变,这是因为两个模板使用了相同的元素,所以会复用,vue这样做是为了高效的渲染元素

    <template v-if="loginType === 'username'">
      <label>Username</label>
      <input placeholder="Enter your username">
    </template>
    <template v-else>
      <label>Email</label>
      <input placeholder="Enter your email address">
    </template>
    

    使用key的情况下,每次切换时,input输入框都将被重新渲染,

    <template v-if="loginType === 'username'">
      <label>Username</label>
      <input placeholder="Enter your username" key="username-input">
    </template>
    <template v-else>
      <label>Email</label>
      <input placeholder="Enter your email address" key="email-input">
    </template>
    

    3. v-show

    v-show切换元素的css属性 display

    <h1 v-show="ok">Hello!</h1>
    

    4. v-if vs v-show

    v-if 切换过程中条件块内的事件监听器和子组件适当地被销毁和重建,如果初始条件为假,则什么都不做,知道变为真时,才会开始渲染条件块

    v-show 不管初始条件是什么,元素总会被渲染,只是简单基于css切换

    根据条件灵活的选用

    5. 注意

    v-show 不支持

  • 相关阅读:
    iOS实时查看App运行日志
    Jmeter-使用Ultimate Thread Group插件来设置负载场景
    Flask使用Flask-SQLAlchemy操作MySQL数据库
    使用requests库提交multipart/form-data 格式的请求
    spark 性能调优(一) 性能调优的本质、spark资源使用原理、调优要点分析
    一、spark错误
    sqoop 补充
    Hbase—— rowkey 过滤器(rowfilter)
    spark 调优——基础篇
    scala 的安装 与 IDEA安装使用
  • 原文地址:https://www.cnblogs.com/redirect/p/8435965.html
Copyright © 2011-2022 走看看