Vue.js(2)----常用指令

Vue.js 使用了基于 HTML 的模版語(yǔ)法捐下,允許開(kāi)發(fā)者聲明式地將 DOM 綁定至底層 Vue 實(shí)例的數(shù)據(jù)。
Vue.js 的核心是一個(gè)允許你采用簡(jiǎn)潔的模板語(yǔ)法來(lái)聲明式的將數(shù)據(jù)渲染進(jìn) DOM 的系統(tǒng)使鹅。
結(jié)合響應(yīng)系統(tǒng),在應(yīng)用狀態(tài)改變時(shí)盐捷, Vue 能夠智能地計(jì)算出重新渲染組件的最小代價(jià)并應(yīng)用到 DOM 操作上孽江。

下面介紹幾種常用指令(v-if、v-show宣鄙、v-else袍镀、v-for、v-bind冻晤、v-on)苇羡,看vue.js如何讓將數(shù)據(jù)渲染進(jìn)入DOM系統(tǒng):

!注意 如果以下代碼不好用鼻弧,請(qǐng)注意頁(yè)面是否引入了可用版本的vue.js设江。引入途徑分為兩種,一種是下載獨(dú)立的vue.js官方下載地址攘轩。也可以使用CDN方法叉存,但是目前國(guó)內(nèi)的不太穩(wěn)定,推薦下載到本地BootCDN(國(guó)內(nèi))度帮、unpkg(國(guó)外)歼捏、cdnjs(國(guó)外)

1. v-if

條件渲染指令笨篷,根據(jù)其后的表達(dá)式的布朗值判斷是否渲染該元素瞳秽。

<div id="view">
    <p v-if="Male">男</p>
    <p v-if="Female">女</p>
    <p v-if="age>20">年齡:{{age}}</p>
  </div>
<script>
var vm= new Vue({
        el:"#view",
        data:{
            Male:true,
            Female: false,
            age:29,
        }
    })
</script>

頁(yè)面效果如下:


查看頁(yè)面元素,可以發(fā)現(xiàn)黃色標(biāo)記區(qū)域是v-if指令渲染出來(lái)的頁(yè)面元素,只渲染了符合條件的元素率翅。

2. v-show

接著v-if直接說(shuō)v-show练俐,上面說(shuō)v-if只渲染符合條件的元素,而v-show則會(huì)渲染全部的元素安聘,讓我們把代碼中的v-if全部替換為v-show痰洒,看看有什么區(qū)別。

可以看到頁(yè)面的顯示與之前的是沒(méi)有區(qū)別的浴韭,但是在頁(yè)面代碼中多了一個(gè)p標(biāo)簽丘喻,并且style='display=none',這說(shuō)明了雖然不符合條件念颈,但v-show依然渲染全部元素泉粉。

3. v-else

v-else指令必須要和v-if、v-show指令搭配在一起才能使用,如果v-if嗡靡、v-show指令的表達(dá)式為true跺撼,那么else元素不顯示;如果v-if讨彼、v-show指令的表達(dá)式為false歉井,則else元素顯示;

<div id="view">
    <p v-if="Male">我是個(gè)男人</p>
    <p v-else>{{message}}</p>
  </div>
<script>
new Vue({
        el:"#view",
        data:{
            Male:false,
            message:"我是個(gè)女人"
        }
    })
</script>

4. v-for

作用是遍歷數(shù)組元素哈误,“item in items”哩至,items是數(shù)組,item是在數(shù)組中的元素蜜自。講個(gè)一個(gè)數(shù)組中包含著很多的人的手機(jī)號(hào)碼菩貌,那么就可以使用v-for遍歷輸出在頁(yè)面中。

<div id="view">
    <table>
        <tr>
            <th>姓名</th>
            <th>號(hào)碼</th>
        </tr>
        <tr v-for="user in users">
            <td>{{ user.name  }}</td>
            <td>{{ user.num  }}</td>
        </tr>
    </table>
</div>
<script>
new Vue({
        el: '#view',
        data: {
            users: [{
                name: '張三',
                num: 12345,
            }, {
                name: '李四',
                num: 67890,
            }, {
                name: '王五',
                num: 12345,
            }, {
                name: '趙六',
                num: 3697810,
            }]
        }
    })
</script>

以上的實(shí)例是在model層保存數(shù)據(jù)重荠,然后再view層使用v-for方法去遍歷model層的數(shù)組箭阶,遍歷后將數(shù)據(jù)顯示在頁(yè)面。

5. v-bind

這個(gè)指令用于實(shí)時(shí)更新HTML元素中的屬性戈鲁,先看下面的實(shí)例:

<style type="text/css">
    .red{
      color: red;
    }
  </style>
</head>
<body>
  <div id="view">
    選中更改字體顏色<input type="checkbox" v-model='red'>
    <div v-bind:class="{'red':red }">字體</div>
  </div>
<script>
new Vue({
        el: '#view',
        data: {
            red:false
        }
    })
</script>

點(diǎn)擊checkbox時(shí)仇参,字體會(huì)更改顏色,也就是添加.red類(lèi)婆殿。view層的input使用了v-model綁定了.red類(lèi)(v-model創(chuàng)建了雙向數(shù)據(jù)綁定冈敛,這里先不細(xì)說(shuō)v-model)。在view層鸣皂,v-bind負(fù)責(zé)它所在元素的屬性抓谴,是否添加red屬性。在model層寞缝,默認(rèn)這個(gè).red類(lèi)為false,即為不添加癌压,當(dāng)更改input中checkbox的布朗值,model層的屬性也會(huì)隨之更改荆陆。v-bind屬性可以有很多應(yīng)用的場(chǎng)景滩届,如網(wǎng)頁(yè)一些需要高亮提示的地方。

6. v-on

用來(lái)監(jiān)聽(tīng)指定元素的DOM事件被啼,比如說(shuō)點(diǎn)擊事件帜消,下面的實(shí)例和我們平常onclick()觸發(fā)某個(gè)函數(shù)是很相似的。

<div id="view">
        <button v-on:click="helo">Helo</button>
</div>
<script>
    var Data ={
      message:'Hello World'
    }
    new Vue({
      el:'#view',
      data:Data,
      methods:{
          helo:function(){
            alert(this.message);
          }
      }
    })
</script>

常用的指令大概就是上面的這幾個(gè)浓体,在編寫(xiě)的時(shí)候要注意不要經(jīng)常寫(xiě)分號(hào)泡挺。筆者習(xí)慣了寫(xiě)js代碼,就一時(shí)有些改不過(guò)來(lái)命浴。
希望大家喜歡這個(gè)系列娄猫,喜歡的話記得點(diǎn)擊那顆小心心贱除,會(huì)給我很多鼓勵(lì)哦!
祝大家周末愉快媳溺。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末月幌,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子悬蔽,更是在濱河造成了極大的恐慌扯躺,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,430評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蝎困,死亡現(xiàn)場(chǎng)離奇詭異缅帘,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)难衰,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,406評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)逗栽,“玉大人盖袭,你說(shuō)我怎么就攤上這事”顺瑁” “怎么了鳄虱?”我有些...
    開(kāi)封第一講書(shū)人閱讀 167,834評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)凭峡。 經(jīng)常有香客問(wèn)我拙已,道長(zhǎng),這世上最難降的妖魔是什么摧冀? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,543評(píng)論 1 296
  • 正文 為了忘掉前任倍踪,我火速辦了婚禮,結(jié)果婚禮上索昂,老公的妹妹穿的比我還像新娘建车。我一直安慰自己,他們只是感情好椒惨,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,547評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布缤至。 她就那樣靜靜地躺著,像睡著了一般康谆。 火紅的嫁衣襯著肌膚如雪领斥。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 52,196評(píng)論 1 308
  • 那天沃暗,我揣著相機(jī)與錄音月洛,去河邊找鬼。 笑死孽锥,一個(gè)胖子當(dāng)著我的面吹牛膊存,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 40,776評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼今艺,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了爵卒?” 一聲冷哼從身側(cè)響起虚缎,我...
    開(kāi)封第一講書(shū)人閱讀 39,671評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤实牡,失蹤者是張志新(化名)和其女友劉穎创坞,沒(méi)想到半個(gè)月后题涨,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,221評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,303評(píng)論 3 340
  • 正文 我和宋清朗相戀三年茂附,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了督弓。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片溶推。...
    茶點(diǎn)故事閱讀 40,444評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖睹耐,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情响委,我是刑警寧澤夹囚,帶...
    沈念sama閱讀 36,134評(píng)論 5 350
  • 正文 年R本政府宣布瞬捕,位于F島的核電站肪虎,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏扇救。R本人自食惡果不足惜陶缺,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,810評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦柬泽、人聲如沸锨并。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,285評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至篱瞎,卻和暖如春牵素,著一層夾襖步出監(jiān)牢的瞬間笆呆,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,399評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工踱讨, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,837評(píng)論 3 376
  • 正文 我出身青樓瘟判,卻偏偏與公主長(zhǎng)得像怨绣,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子桐筏,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,455評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容

  • 這篇筆記主要包含 Vue 2 不同于 Vue 1 或者特有的內(nèi)容踱葛,還有我對(duì)于 Vue 1.0 印象不深的內(nèi)容剖毯。關(guān)于...
    云之外閱讀 5,052評(píng)論 0 29
  • 1.安裝 可以簡(jiǎn)單地在頁(yè)面引入Vue.js作為獨(dú)立版本擂达,Vue即被注冊(cè)為全局變量土铺,可以在頁(yè)面使用了。 如果希望搭建...
    Awey閱讀 11,034評(píng)論 4 129
  • Vue 實(shí)例 屬性和方法 每個(gè) Vue 實(shí)例都會(huì)代理其 data 對(duì)象里所有的屬性:var data = { a:...
    云之外閱讀 2,220評(píng)論 0 6
  • 你會(huì)講故事嗎? 大多銷(xiāo)售員的套路:一見(jiàn)到客戶(hù),上來(lái)就是性?xún)r(jià)比俭令、價(jià)格后德、質(zhì)量、以及性能如何抄腔,客戶(hù)聽(tīng)過(guò)很多次競(jìng)品這樣講瓢湃,...
    烏鴉不眠閱讀 953評(píng)論 0 0
  • 三十知禮而立 一米八 清瘦 開(kāi)朗 喜歡看喪尸理张。 一夜一天前在嘲笑我爛透了的廚藝!起因是我不會(huì)用微...
    一個(gè)原住民閱讀 230評(píng)論 0 1