溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Vue中數(shù)據(jù)綁定的示例分析

發(fā)布時(shí)間:2021-08-13 11:21:42 來(lái)源:億速云 閱讀:88 作者:小新 欄目:web開(kāi)發(fā)

這篇文章主要為大家展示了“Vue中數(shù)據(jù)綁定的示例分析”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“Vue中數(shù)據(jù)綁定的示例分析”這篇文章吧。

為什么綁定

簡(jiǎn)單的數(shù)據(jù)渲染,包括表達(dá)式、函數(shù)在內(nèi)。其實(shí)都只是在標(biāo)簽中渲染,如果遇到以下情況怎么辦呢:

需要在標(biāo)簽內(nèi)部進(jìn)行某種 "騷操作" 。

需要控制流來(lái)控制不同數(shù)據(jù)下的不同渲染效果。

需要渲染一個(gè)數(shù)組。

這時(shí)候簡(jiǎn)單渲染就不能很好的解決問(wèn)題了,怎么辦 ?

來(lái)一發(fā)數(shù)據(jù)綁定吧!

綁定是什么

在了解綁定是什么之前,先了解一下什么是指令:

在 " vue" 中,指令是帶有 v- 前綴的特殊屬性,用來(lái)修飾標(biāo)簽的(自定義組件在這里也統(tǒng)一歸為標(biāo)簽,因?yàn)槠涫褂梅绞胶驮鷺?biāo)簽一樣),其值的約束和模板語(yǔ)法一樣,支持表達(dá)式、變量。

指令會(huì)監(jiān)測(cè)其值的變化,并將其的變化反應(yīng)給所處的DOM

我們來(lái)看一下上一章最后的例子:

<h2>{{ if(msg == '1') return time }}</h2>

在這里我們是想利用控制流來(lái)控制是否顯示時(shí)間,但是很遺憾,模板語(yǔ)法并不支持js語(yǔ)法。

但是 " vue" 中有這樣一個(gè)指令來(lái)彌補(bǔ)模板語(yǔ)法不支持 js語(yǔ)法的遺憾:

v-if

下面看看修改后的代碼:

<h2 v-if="msg=='1'">{{ formatTime(time) }}</h2>

先將 msg的值賦值為1

Vue中數(shù)據(jù)綁定的示例分析

然后再修改一下 msg的值看看:

Vue中數(shù)據(jù)綁定的示例分析

什么也沒(méi)有顯示,因?yàn)槲覀?msg的值并不是 1。

v-if 指令很完美的解決了我們最開(kāi)始提出來(lái)的第二個(gè)問(wèn)題:

需要控制流來(lái)控制不同數(shù)據(jù)下的不同渲染效果。

讓我們回到最開(kāi)始的話題。

這就是指令,而在官方原生的指令中,有一個(gè)指令是專門(mén)用來(lái)綁定標(biāo)簽屬性的:

v-bind

命名很形象,bind 直譯就是綁定的意思。

如何綁定

這里利用 div標(biāo)簽展示一下 v-bind 的使用方式,用在其它標(biāo)簽上同理:

<div v-bind:屬性名="表達(dá)式"></div>

我們拿第一個(gè)問(wèn)題舉例實(shí)踐一下:

需要在標(biāo)簽內(nèi)部進(jìn)行某種 "騷操作"。

這里我們就根據(jù) isDark的值來(lái)確定時(shí)間顯示的背景色吧

當(dāng) isDark為 true 的時(shí)候,背景色變成黑色,文字變成白色。

當(dāng) isDark為 false的時(shí)候,背景色變成白色,文字變成黑色。

先來(lái)定義 isDark:

data() {
  return {
   msg: 'hello vue',
   time: new Date(),
   isDark: False
  }
 }

然后添加一下兩種條件下的樣式:

<style>
 .dark{
  background-color: black;
  color: white;
 }

 .light{
  background-color: white;
  color: black;
 }
</style>

接下來(lái)給 h2標(biāo)簽加上綁定指令:

<h2 v-bind:class="isDark ? 'dark' : 'light'">{{ formatTime(time) }}</h2>

效果如下:

Vue中數(shù)據(jù)綁定的示例分析

我們將 isDark 的值修改成 true:

Vue中數(shù)據(jù)綁定的示例分析

很完美的達(dá)到了所需求的效果。

這就是指令的魅力。

最后一個(gè)問(wèn)題

上述兩個(gè)指令解決了我們最初提出來(lái)三個(gè)問(wèn)題中的兩個(gè),那么剩下一個(gè)呢?

需要渲染一個(gè)數(shù)組。

當(dāng)我們需要渲染表格的時(shí)候就會(huì)遇到這個(gè)場(chǎng)景,如何去渲染一個(gè)數(shù)組呢?模板語(yǔ)法又并不支持這么復(fù)雜的操作。

請(qǐng)出本章最后一個(gè)指令:

v-for

嗯,還是很形象。js里面也有 for 嘛~

先看看它是做什么的:

v-for 會(huì)為數(shù)據(jù)源(綁定的列表)中的每一項(xiàng),生成一個(gè)同類(lèi)的標(biāo)簽。

然后看看怎么用,這里用 a 標(biāo)簽做說(shuō)明,其他標(biāo)簽類(lèi)似:

<!-- 寫(xiě)法1 -->

<a v-for="別名 in 數(shù)據(jù)源" v-bind:key="唯一標(biāo)識(shí)">{{ 別名.字段 }}</a>

<!-- 寫(xiě)法2 -->

<a v-for="(下標(biāo), 別名) in 數(shù)據(jù)源" v-bind:key="唯一標(biāo)識(shí)">{{ 別名.字段 }}</a>

因?yàn)樾掳姹镜?vue要求使用 v-for指令渲染的標(biāo)簽必須綁定一個(gè)key用做唯一標(biāo)識(shí),大多數(shù)情況下我們可以直接使用下標(biāo)來(lái)進(jìn)行標(biāo)識(shí)

繼續(xù)使用我們之前的代碼進(jìn)行演示,先定義一個(gè) url的數(shù)組:

data() {
  return {
   msg: 'hello vue',
   time: new Date(),
   isDark: true,
   urlList: [
    {
     text: '鏈接1',
     url: '#1'
    },

    {
     text: '鏈接2',
     url: '#2'
    },

    {
     text: '鏈接3',
     url: '#3'
    }
   ]
  }
 }

然后渲染安排一波:

<a v-for="(item, index) in urlList" v-bind:key="index" v-bind:href="item.url" rel="external nofollow" >{{item.text}}</a>

效果如下:

Vue中數(shù)據(jù)綁定的示例分析

渲染的結(jié)果是三個(gè) a 標(biāo)簽,非常正確~

很完美的解決了最后一個(gè)問(wèn)題。

還有些什么指令呢?

官方還有其他的指令,這里再提一個(gè):

v-on

v-on 指令可以綁定事件,比如說(shuō)按鈕的點(diǎn)擊事件。

像上面切換背景的例子中,可以通過(guò)一個(gè)按鈕的點(diǎn)擊事件來(lái)修改 isDark的值,從而控制背景的改變。就不需要每次都手動(dòng)來(lái)修改下 isDark的值了。

以上是“Vue中數(shù)據(jù)綁定的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

vue
AI