iT邦幫忙

2024 iThome 鐵人賽

DAY 8
2
Modern Web

欸你是要進 Vue 了沒?系列 第 8

欸你是要進 Vue 了沒? - Day8:Vue 模板語法【屬性綁定】

  • 分享至 

  • xImage
  •  

昨天提到了 Vue 中的模板語法 Mustachev-html,今天來看看「屬性綁定」。

定義

屬性綁定可以響應式的綁定「HTML」的 idsrcclass 等等屬性,使這些屬性能夠「隨著數據變化自動更新」。

小道消息

{{ }} 文本插值語法,雖然能在模板內插入值,但不能用來直接綁定 HTML 屬性!
例如:<div id="{{ example }}"></div> 像這樣要去綁定 HTML 的 id 屬性是無效的,不過我們可以使用 v-bind 做到!

語法

v-bind:要綁定的屬性=""

例如:<div v-bind:id="example"></div>
這個 <div>id 屬性會與 example 保持同步,當 example 的值改變時,<div>id 也會隨之改變。

屬性綁定的特點就是「響應性」,當綁定的數據改變時,Vue 就會負責處理所有的 UI 更新。

我們可以透過簡單的變數來測試看看這個響應性效果~

範例

https://ithelp.ithome.com.tw/upload/images/20240921/20169139GsNkCJPiq0.png

<script setup>
const dynamicId = "div1";
</script>

<template>
  <div v-bind:id="dynamicId">Here is v-bind example!</div>
</template>

<style>
#div1 {
  color: red;
}
</style>

其中會發生什麼事?

<div> 使用 v-bind:id="dynamicId" 綁定時,其 id 的值會與 <script setup> 中定義的 dynamicId 保持一致,而dynamicId 的值是 div1,所以對應的 CSS 樣式將會生效。

瀏覽器上將會渲染為:<div id="div1"></div>,文字變成紅色。
https://ithelp.ithome.com.tw/upload/images/20240921/20169139zOJ6G67875.png

而如果我將 dynamicId 改為 div2 的時候!
https://ithelp.ithome.com.tw/upload/images/20240921/20169139qA1rAPIla6.png

將會渲染到 #div2 這段 style,文字變成綠色。
https://ithelp.ithome.com.tw/upload/images/20240921/20169139HoTJG0NA7V.png

目前 Vue 3.4 版,可以將 v-bind: 簡寫(將 : 前的文字去掉)
例如要綁定 class 屬性即寫:<div :class="example"></div>

那我們來試試看用簡寫 : 綁定 class,看範例!
https://ithelp.ithome.com.tw/upload/images/20240921/20169139VYrVAD7sfc.png

<script setup>
  const button = "button";
</script>

<template>
  <button :class="button">Here is button example!</button>
</template>

在這個範例:
<button> 使用 :class 綁定變數 button,所以 button 變數的值會與 <script setup> 中定義的 const button = "button" 保持一致。
這讓按鈕的 class 屬性等於 button,所以 CSS 中定義的 .button { background-color: yellow; } 會套用到按鈕上。

瀏覽器上將會渲染為 <button class="button"></button>,按鈕背景變為黃色~
https://ithelp.ithome.com.tw/upload/images/20240921/20169139Ub49hqizOM.png

布爾型屬性(Boolean attributes)

是 HTML 中的一種屬性,特點是「屬性存在與否」表示了該屬性的狀態,而「不需要賦值」,例如:disabledcheckedreadonly 等屬性。
例如:當 disabled 綁定的值為「真值」時,屬性會存在,「假值」時,屬性會被移除。

範例

接下來用範例示範定義真值與假值的差別,我們設置兩個 button:一個將值綁定為 true,一個綁定為 false

https://ithelp.ithome.com.tw/upload/images/20240921/20169139cHe2Hwq2OK.png

<script setup>
const isButtonDisabled = true;
const isButtonDisabled2 = false;
</script>

<template>
  <button :disabled="isButtonDisabled">Here is disabledButton example!</button>
  <button :disabled="isButtonDisabled2">Here is disabledButton example!</button>
</template>

瀏覽器上將會渲染為:
https://ithelp.ithome.com.tw/upload/images/20240921/201691396nmGo7ihul.png

第一個按鈕,由於 isButtonDisabled 綁定為 true,因此 disabled 屬性會存在 >> 按鈕將處於「禁用」狀態。
第二個按鈕,由於 isButtonDisabled2 綁定為 false,因此 disabled 屬性不會存在 >> 按鈕處於「可用」狀態。

動態綁定多個值

想要同時綁定多個值怎麼辦?我想同時綁定 idclass 呢?
可以使用「不帶參數的 v-bind」綁定。

語法

v-bind = ""

"" 中的值,我們可以用「物件」把它包起來,我們來看看以下的範例。

範例

<template>
  <p v-bind="objAttributes">
    Lorem ipsum dolor sit amet consectetur adipisicing elit. Nostrum accusamus ex reprehenderit commodi illo veniam exercitationem quia eius laborum doloribus.</p>
</template>

<script setup>
const objAttributes = {
  id: "div3",
  class: "mainContent",
};
</script>

<style>
#div3 {
  color: blue;
}
.mainContent {
  background-color: plum;
}
</style>

<p>v-bind 綁定了 objAttributes 這個值,所以 <script setup>objAttributes 定義的 idclass 的值,會綁定到 <p> 上。

瀏覽器上將會渲染為:
https://ithelp.ithome.com.tw/upload/images/20240921/20169139HfZ7a3GxK3.png
藍色文字、和李子色背景~

小結

動態綁定好像有點好玩,讓我要渲染資料變得有夠迅速,明天來看一下使用「 JavaScript 表達式」的語法(聽起來有點恐怖)
/images/emoticon/emoticon37.gif

範例 code ⬇️

參考資料


上一篇
欸你是要進 Vue 了沒? - Day7:Vue 模板語法【Mustache、v-html】
下一篇
欸你是要進 Vue 了沒? - Day9:Vue 模板語法【JS 表達式】
系列文
欸你是要進 Vue 了沒?30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

1 則留言

1
jeremykuo
iT邦新手 5 級 ‧ 2024-09-22 00:29:02

一瞬間就穿好整套屬性了呢!然後終於要到表達式了嗎/images/emoticon/emoticon39.gif

我要留言

立即登入留言