Day 5 - 条件渲染与列表渲染

v-if 条件渲染

Vue 之中还有一个相当实用的功能就是条件渲染了,条件渲染类似於使用 if else 控制状况,只是现在是控制什麽样的状况下进行 DOM 的渲染。

如下面程序码所示,我们为div设定条件渲染,当 isShow 变数为 true 时才进行渲染,false 时则否。

当我们把isShow从 true 改为 false 之後可以发现浏览器上的"我是 v if 文字就消失了"。

<template>
    <div v-if="isShow">我是 v if</div>
</template>

<script>
export default {
  name: "App",
  data() {
    return {
      isShow: true
    };
  },
</script>

除了v-if外,我们也可以搭配 v-else 指定剩下的状况。

这时候如果把 isShow 改成 false,就会发现印出了"我是 v if false"。

v-for 列表渲染

在Vue中,也提供了方法让我们可以遍历物件,并显示在页面上。

而v-for 用法如下:

我们在Data中宣告了一个用来存放使用者名字及年龄的阵列,并透过v-for遍历这个物件。

使用v-for迭代物件中的元素。第一个参数是用来存放资料内容的物件,第二个参数 key 是键值,第三个参数 index 是索引值,第二个参数和第三个参数皆为 optional。

此外,可透过 :key="index" 取得该笔资料的唯一值,避免资料渲染时有错误产生。

<template>
  <div id="app">
    <li v-for="(item, index) in nameArray" :key="index">
      name:{{ item.name }}, age:{{ item.age }}
    </li>
  </div>
</template>

<script>
export default {
  name: "App",
  data() {
    return {
      nameArray: [
        { name: "Grant", age: 26 },
        { name: "Amy", age: 28 },
        { name: "Linda", age: 30 },
      ],
    };
  },
};
</script>

成果如下:
https://ithelp.ithome.com.tw/upload/images/20210920/20128925wOATRcxVVw.png

我们也可以将v-for搭配其他的DOM元素,如table。

<template>
  <div id="app">
    <table>
      <th>name</th>
      <th>age</th>
      <tr v-for="(item, index) in nameArray" :key="index">
        <td>{{ item.name }}</td>
        <td>{{ item.age }}</td>
      </tr>
    </table>
  </div>

以上就是条件渲染与列表渲染的用法~

可透过以下网址获取demo code:

https://codesandbox.io/s/quirky-mirzakhani-imtby?file=/src/App.vue


<<:  Day05 捷径环境介绍

>>:  [Day5] Holt's Model 介绍

Day09 - 套用 Html Helper - 复杂型别 object + object collection

Case01 跟 Day06、Day08 范例差不多,重点差异如下: Controller 於 Ge...

[Python 爬虫这样学,一定是大拇指拉!] DAY25 - 实战演练:关於多执行绪

多执行绪 介绍什麽是多执行绪(multithreading)前,先来简单讲一下什麽是执行绪。 在作业...

Day30:总结

一开始 30天以前,我以为我会放弃,刚开始一天要花4到6小时才能产出一篇文章,这样的状态维持了一周後...

Day06 - 监控 Sidekiq 有无正常运作(或执行超过多久)

前言 去年介绍过 Day25 - Ruby on Rails 中的 Sidekiq 的介绍与应用 ,...

[想试试看JavaScript ] 讲了好几天的 callback,callback function 是什麽呢?

callback function callback function 也叫回呼函式 Callbac...