条件渲染与列表渲染

条件渲染

条件渲染,就满足一定的条件以后才会渲染。

v-if

v-if指令类似于,js中的if语句,当条件满足时才会执行

<span v-if="ok">v-if</span> //ok的值为true,span标签才会被渲染
<template v-if="ok"> //同时渲染多个元素
  <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语句,当v-if条件不成立是,v-else就会渲染。

<span v-if="ok">v-if</span>
<span v-else>v-else</span> //当ok 的值为false,是渲染

v-else必须紧跟着在v-if或者v-else-if的到后面,否则不会被识别。

v-else-if

2.1.0新增加的指令,类似于js中的else if,可以链式使用多次。

<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的到后面,否则不会被识别。

用key管理可复用的元素

vue会尽可能的高效的渲染元素,通常会复用已有元素而不会从头渲染

 <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>

上面例子因为两个p标签用用了相同的元素,<input>不会被替换掉,仅仅是替换了他的placeholder

username显示时,输入框里面输入的1

切换到,email是1任然存在,说明input是复用之前的input

当我们不想复用他们时,只要加上唯一的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不见了,说明两个input不是同一个,没有复用之前的了

注意, <label> 元素仍然会被高效地复用,因为它们没有添加 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 是真正的条件渲染,因为他确保在切换过程中条件块内部的事件监听器和子组件适当的被销毁和重建
  • v-if也是惰性的,如果在处事渲染时条件为假,则什么也不做,直到条件为真时,才开始渲染条件块
  • v-show就简单的多,不管条件是啥总会被渲染,并且只是简单的基于css的切换
  • 一般需要频繁的切换就是用v-show,运行条件不太会改变则使用v-if
  • v-ifv-for 一起使用时,v-for 具有比 v-if 更高的优先级

列表渲染

v-for

我们用 v-for 指令根据一组数组的选项列表进行渲染。基本用法如下:

<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 还支持可选的第二个参数为当前项的索引

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

利用template标签同时渲染多个标签

<ul>
      <template v-for="(val, index) in items">
          <li>{{index}}</li>
          <li>{{val.text}}</li>
       </template>
 </ul>
同时渲染两个li的示例

对象的迭代,是按 Object.keys() 的结果遍历,但是不能保证它的结果在不同的 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>
对象迭代示例
<button v-for="i in 10">{{i}}</button>
整数迭代示例

当迭代渲染遇上组件

<div id="#app">
    <my-ul :items="items"></my-ul> //将数据注入子组件
</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']  //接受父组件传进了的数据
    });
 var vm = new Vue({
        el: '#app',
        data: {
           items: [
               {text: 'item1'},
               {text: 'item2'},
               {text: 'item3'}
           ]
        }
    });
</script>
组件循环示例

key

Vue.jsv-for 正在更新已渲染过的元素列表时,它默认用 “就地复用” 策略。
建议尽可能使用v-for 来提供 key ,除非迭代 DOM 内容足够简单,或者你是故意要依赖于默认行为来获得性能提升。用法跟前面一样。

数组的更新检查

Vue包含一组观察数组的变异方法,所以它们也将会触发视图更新。这些方法如下

  • push()
  • pop()
  • shift()
  • unshift()
  • splice()
  • sort()
  • reverse()
    这些方法都会改变原数组,也有一些方法是返回一个新数组,不会改变原数组。例如: filter(), concat(), slice() 。当使用非变异方法时,可以用新数组替换旧数组。
    注意事项
    由于 JavaScript 的限制, Vue 不能检测以下变动的数组:
  • 当你利用索引直接设置一个项时,例如: vm.items[indexOfItem] = newValue
  • 当你修改数组的长度时,例如: vm.items.length = newLength

解决方法:

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

数据过滤

我们想要显示一个数组的过滤或排序副本,而不实际改变或重置原始数据。

 奇数:<span v-for="i in odd">{{i}}</span>
 偶数:<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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容

  • 条件渲染 v-if指令 ​ 利用v-if指令,可以实现在同一页面,不同的时期,根据需要渲染显示不同的块或模板<te...
    Husbin阅读 450评论 0 0
  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,044评论 0 29
  • Vue 实例 属性和方法 每个 Vue 实例都会代理其 data 对象里所有的属性:var data = { a:...
    云之外阅读 2,198评论 0 6
  • 1.安装 可以简单地在页面引入Vue.js作为独立版本,Vue即被注册为全局变量,可以在页面使用了。 如果希望搭建...
    Awey阅读 10,982评论 4 129
  • 1、我国古代三大化学工艺:造纸,制火药,烧瓷器。 2、氧化反应的三种类型:爆炸,燃烧,缓慢氧化。 3、构成物质的三...
    老师课堂阅读 277评论 0 0