條件渲染與列表渲染

條件渲染

條件渲染嘴高,就滿足一定的條件以后才會(huì)渲染贸呢。

v-if

v-if指令類似于奏司,js中的if語句,當(dāng)條件滿足時(shí)才會(huì)執(zhí)行

<span v-if="ok">v-if</span> //ok的值為true谎砾,span標(biāo)簽才會(huì)被渲染
<template v-if="ok"> //同時(shí)渲染多個(gè)元素
  <h1>Title</h1>
  <p>Paragraph 1</p>
  <p>Paragraph 2</p>
</template>
var vm = new Vue({
       el: '#app',
       data: {
           ok: true,
           no: true,
           type: 'c',
           toggle: true
       }
   });

v-else

v-else指令逢倍,類似于js中的else語句,當(dāng)v-if條件不成立是景图,v-else就會(huì)渲染较雕。

<span v-if="ok">v-if</span>
<span v-else>v-else</span> //當(dāng)ok 的值為false,是渲染

v-else必須緊跟著在v-if或者v-else-if的到后面挚币,否則不會(huì)被識(shí)別亮蒋。

v-else-if

2.1.0新增加的指令,類似于js中的else if忘晤,可以鏈?zhǔn)绞褂枚啻巍?/p>

<p v-if="type === 'a'">a</p>
<p v-else-if="type === 'b'">b</p>
<p v-else="">not a and b</p>

v-else-if必須緊跟著在v-if或者v-else-if的到后面宛蚓,否則不會(huì)被識(shí)別激捏。

用key管理可復(fù)用的元素

vue會(huì)盡可能的高效的渲染元素设塔,通常會(huì)復(fù)用已有元素而不會(huì)從頭渲染

 <p v-if="toggle"><label>username </label> <input type="text" placeholder="username"></p>
 <p v-else=""><label>email</label> <input type="text" placeholder="email"></p>
 <button @click="toggle = !toggle">toggle</button>

上面例子因?yàn)閮蓚€(gè)p標(biāo)簽用用了相同的元素,<input>不會(huì)被替換掉,僅僅是替換了他的placeholder闰蛔。

username顯示時(shí)痕钢,輸入框里面輸入的1

切換到,email是1任然存在序六,說明input是復(fù)用之前的input

當(dāng)我們不想復(fù)用他們時(shí)任连,只要加上唯一的key屬性

<p v-if="toggle"><label>username </label> <input type="text" placeholder="username" key="username"></p>
<p v-else=""><label>email</label> <input type="text" placeholder="email" key="email"></p>
<button @click="toggle = !toggle">toggle</button>
加上可以以后,在username上輸入了1
切換到email下例诀,1不見了随抠,說明兩個(gè)input不是同一個(gè),沒有復(fù)用之前的了

注意, <label> 元素仍然會(huì)被高效地復(fù)用繁涂,因?yàn)樗鼈儧]有添加 key 屬性拱她。

v-show

v-show與v-if的用法幾乎一致

<span v-show="ok">v-show</span>

v-show VS v-if

  • v-show不支持 <template> 語法,也不支持v-else扔罪。
  • v-if 是真正的條件渲染秉沼,因?yàn)樗_保在切換過程中條件塊內(nèi)部的事件監(jiān)聽器和子組件適當(dāng)?shù)谋讳N毀和重建
  • v-if也是惰性的,如果在處事渲染時(shí)條件為假矿酵,則什么也不做唬复,直到條件為真時(shí),才開始渲染條件塊
  • v-show就簡單的多全肮,不管條件是啥總會(huì)被渲染敞咧,并且只是簡單的基于css的切換
  • 一般需要頻繁的切換就是用v-show,運(yùn)行條件不太會(huì)改變則使用v-if
  • 當(dāng) v-ifv-for 一起使用時(shí)辜腺,v-for 具有比 v-if 更高的優(yōu)先級(jí)

列表渲染

v-for

我們用 v-for 指令根據(jù)一組數(shù)組的選項(xiàng)列表進(jìn)行渲染妄均。基本用法如下:

<div id="app">
    <ul>
         <li v-for="item in items" v-text="item.text"></li>
    </ul>
</div>
var vm = new Vue({
        el: '#app',
        data: {
           items: [
               {text: 'item1'},
               {text: 'item2'},
               {text: 'item3'}
           ]
        }
});
基本用法示例

v-for 還支持可選的第二個(gè)參數(shù)為當(dāng)前項(xiàng)的索引

<ul>
      <li v-for="(val,index) in items" v-text="(index+1) + '. ' + val.text"></li>
</ul>
帶了索引的示例

利用template標(biāo)簽同時(shí)渲染多個(gè)標(biāo)簽

<ul>
      <template v-for="(val, index) in items">
          <li>{{index}}</li>
          <li>{{val.text}}</li>
       </template>
 </ul>
同時(shí)渲染兩個(gè)li的示例

對(duì)象的迭代哪自,是按 Object.keys() 的結(jié)果遍歷丰包,但是不能保證它的結(jié)果在不同的 JavaScript 引擎下是一致的

<span v-for="key in obj">{{key}}</span>
<p v-for="(key, value) in obj">{{key}}: {{value}}</p>
<p v-for="(key, value, index) in obj">{{key}}: {{value}}: {{index}}</p>
對(duì)象迭代示例
<button v-for="i in 10">{{i}}</button>
整數(shù)迭代示例

當(dāng)?shù)秩居錾辖M件

<div id="#app">
    <my-ul :items="items"></my-ul> //將數(shù)據(jù)注入子組件
</div>
<template id="myul">
    <ul>
        <li v-for="i in items">{{i.text}}</li>
    </ul>
</template>
<script>
    Vue.component('my-ul',{
        template: '#myul',
        props: ['items']  //接受父組件傳進(jìn)了的數(shù)據(jù)
    });
 var vm = new Vue({
        el: '#app',
        data: {
           items: [
               {text: 'item1'},
               {text: 'item2'},
               {text: 'item3'}
           ]
        }
    });
</script>
組件循環(huán)示例

key

當(dāng) Vue.jsv-for 正在更新已渲染過的元素列表時(shí),它默認(rèn)用 “就地復(fù)用” 策略壤巷。
建議盡可能使用v-for 來提供 key 邑彪,除非迭代 DOM 內(nèi)容足夠簡單,或者你是故意要依賴于默認(rèn)行為來獲得性能提升胧华。用法跟前面一樣寄症。

數(shù)組的更新檢查

Vue包含一組觀察數(shù)組的變異方法,所以它們也將會(huì)觸發(fā)視圖更新矩动。這些方法如下

  • push()
  • pop()
  • shift()
  • unshift()
  • splice()
  • sort()
  • reverse()
    這些方法都會(huì)改變原數(shù)組有巧,也有一些方法是返回一個(gè)新數(shù)組,不會(huì)改變原數(shù)組悲没。例如: filter(), concat(), slice() 五垮。當(dāng)使用非變異方法時(shí),可以用新數(shù)組替換舊數(shù)組婴谱。
    注意事項(xiàng)
    由于 JavaScript 的限制, Vue 不能檢測以下變動(dòng)的數(shù)組:
  • 當(dāng)你利用索引直接設(shè)置一個(gè)項(xiàng)時(shí)逊笆,例如: vm.items[indexOfItem] = newValue
  • 當(dāng)你修改數(shù)組的長度時(shí),例如: vm.items.length = newLength

解決方法:

Vue.set(example1.items, indexOfItem, newValue)
example1.items.splice(indexOfItem, 1, newValue)
example1.items.splice(newLength)

數(shù)據(jù)過濾

我們想要顯示一個(gè)數(shù)組的過濾或排序副本岂傲,而不實(shí)際改變或重置原始數(shù)據(jù)难裆。

 奇數(shù):<span v-for="i in odd">{{i}}</span>
 偶數(shù):<span v-for="i in even(number)">{{i}}</span>

 var vm = new Vue({
        el: '#app',
        data: {                
            number: [1,2,3,4,5,6]
        },
        computed: {
            odd: function(){
                return this.number.filter(function(i){
                    return i%2 === 1;
                })
            }
        },
        methods: {
            even: function(arr){
                return arr.filter(function(i){
                    return i%2 === 0;
                })
            }
        }

    });
過濾示例

官方API

Vue

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市镊掖,隨后出現(xiàn)的幾起案子乃戈,更是在濱河造成了極大的恐慌,老刑警劉巖亩进,帶你破解...
    沈念sama閱讀 212,718評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件偏化,死亡現(xiàn)場離奇詭異,居然都是意外死亡镐侯,警方通過查閱死者的電腦和手機(jī)侦讨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來苟翻,“玉大人韵卤,你說我怎么就攤上這事〕缑ǎ” “怎么了沈条?”我有些...
    開封第一講書人閱讀 158,207評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長诅炉。 經(jīng)常有香客問我蜡歹,道長,這世上最難降的妖魔是什么涕烧? 我笑而不...
    開封第一講書人閱讀 56,755評(píng)論 1 284
  • 正文 為了忘掉前任月而,我火速辦了婚禮,結(jié)果婚禮上议纯,老公的妹妹穿的比我還像新娘父款。我一直安慰自己,他們只是感情好瞻凤,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,862評(píng)論 6 386
  • 文/花漫 我一把揭開白布憨攒。 她就那樣靜靜地躺著,像睡著了一般阀参。 火紅的嫁衣襯著肌膚如雪肝集。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,050評(píng)論 1 291
  • 那天蛛壳,我揣著相機(jī)與錄音杏瞻,去河邊找鬼所刀。 笑死,一個(gè)胖子當(dāng)著我的面吹牛伐憾,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播赫模,決...
    沈念sama閱讀 39,136評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼树肃,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了瀑罗?” 一聲冷哼從身側(cè)響起胸嘴,我...
    開封第一講書人閱讀 37,882評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎斩祭,沒想到半個(gè)月后劣像,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,330評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡摧玫,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,651評(píng)論 2 327
  • 正文 我和宋清朗相戀三年耳奕,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片诬像。...
    茶點(diǎn)故事閱讀 38,789評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡屋群,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出坏挠,到底是詐尸還是另有隱情芍躏,我是刑警寧澤,帶...
    沈念sama閱讀 34,477評(píng)論 4 333
  • 正文 年R本政府宣布降狠,位于F島的核電站对竣,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏榜配。R本人自食惡果不足惜否纬,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,135評(píng)論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蛋褥。 院中可真熱鬧烦味,春花似錦、人聲如沸壁拉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽弃理。三九已至溃论,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間痘昌,已是汗流浹背钥勋。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評(píng)論 1 267
  • 我被黑心中介騙來泰國打工炬转, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人算灸。 一個(gè)月前我還...
    沈念sama閱讀 46,598評(píng)論 2 362
  • 正文 我出身青樓扼劈,卻偏偏與公主長得像,于是被迫代替她去往敵國和親菲驴。 傳聞我的和親對(duì)象是個(gè)殘疾皇子荐吵,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,697評(píng)論 2 351

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

  • 條件渲染 v-if指令 ? 利用v-if指令,可以實(shí)現(xiàn)在同一頁面赊瞬,不同的時(shí)期先煎,根據(jù)需要渲染顯示不同的塊或模板<te...
    Husbin閱讀 452評(píng)論 0 0
  • 這篇筆記主要包含 Vue 2 不同于 Vue 1 或者特有的內(nèi)容,還有我對(duì)于 Vue 1.0 印象不深的內(nèi)容巧涧。關(guān)于...
    云之外閱讀 5,046評(píng)論 0 29
  • Vue 實(shí)例 屬性和方法 每個(gè) Vue 實(shí)例都會(huì)代理其 data 對(duì)象里所有的屬性:var data = { a:...
    云之外閱讀 2,204評(píng)論 0 6
  • 1.安裝 可以簡單地在頁面引入Vue.js作為獨(dú)立版本薯蝎,Vue即被注冊為全局變量,可以在頁面使用了谤绳。 如果希望搭建...
    Awey閱讀 11,003評(píng)論 4 129
  • 1占锯、我國古代三大化學(xué)工藝:造紙,制火藥缩筛,燒瓷器烟央。 2、氧化反應(yīng)的三種類型:爆炸歪脏,燃燒疑俭,緩慢氧化。 3婿失、構(gòu)成物質(zhì)的三...
    老師課堂閱讀 278評(píng)論 0 0