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

    渲染:条件渲染,列表渲染

    1.条件渲染

    v-if、v-else、v-else-if       v-else、v-else-if 必须跟在v-if、v-else-if 之后否则不会被识别

    <div v-if="Math.random() > 0.5">
      Now you see me
    </div>
    <div v-else>
      Now you don't
    </div>
    <!-- 如果切换多个元素,可以在外面包含一层template,template不会显示 -->
    <template v-if="ok">
      <h1>Title</h1>
      <p>Paragraph 1</p>
      <p>Paragraph 2</p>
    </template>
    <!--  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>

    key管理可复用的元素

    下面例子中,input如果没有添加key,会复用,切换时,用户输入的值,会保留,只是替换了placeholder

    添加了唯一值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>

    v-show    v-show始终渲染,只是切换display属性,不支持<template>元素

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

    v-if与v-show的区别

    • v-if只有当满足条件时,才会被渲染。v-show是一直都会渲染且存在。
    • v-if会销毁和重建。v-show并不会销毁,只会切换css的display属性。
    • 如果运行时条件很少改变,则使用v-if。如果会频繁切换,则使用v-show。

    2.列表渲染

    v-for   v-for指令根据一组数组的选项列表进行渲染。绑定key:key 防止重用和重新排序现有元素

    渲染数组

    item in items语法,可以使用 of 代替 in,支持可选的第二个参数 (item, index) in items

    <ul id="example-1">
      <li v-for="item in items"  :key="item.id">
        {{ item.message }}
      </li>
    </ul>
    <!-- 带index -->
    <ul id="example-2">
      <li v-for="(item, index) in items">
        {{ parentMessage }} - {{ index }} - {{ item.message }}
      </li>
    </ul>
    var example1 = new Vue({
      el: '#example-1',
      data: {
        items: [
          { message: 'Foo' },
          { message: 'Bar' }
        ]
      }
    })

    v-for和v-if

    当v-for和v-if处于同一节点时,v-for的优先级比v-if的优先级高。如果你是有条件的跳过循环的执行,可以将v-if置于外层元素(或<template>)。

    <li v-for="todo in todos" v-if="!todo.isComplete">
      {{ todo }}
    </li>
    //只显示未完成的todo
    <ul v-if="todos.length">
      <li v-for="todo in todos">
        {{ todo }}
      </li>
    </ul>
    <p v-else>No todos left!</p>
    //置于外层循环

    渲染对象

    value in object方法,支持第二个参数key和第三个参数index 

    <div v-for="(value, key, index) in object">
      {{ index }}. {{ key }}: {{ value }}
    </div>
    new Vue({
      el: '#v-for-object',
      data: {
        object: {
          firstName: 'John',
          lastName: 'Doe',
          age: 30
        }
      }
    })
  • 相关阅读:
    如何设计API返回码(错误码)?
    处理git项目内部结构一个变多个子包后提交失败问题
    mysql触发器例子
    使用kafka客戶端例子(开启kerberos验证)
    Shell脚本应用(for、while循环语句和case分支语句)
    Linux防火墙基础与编写防火墙规则
    Squid代理服务器
    rsync远程同步的基本配置与使用
    Shell脚本应用(if语句的结构)
    Shell的基础介绍和案例
  • 原文地址:https://www.cnblogs.com/zsj-02-14/p/10483367.html
Copyright © 2011-2022 走看看