VUE 入门基础(6)
六,条件渲染
v-if 添加一个条件块
<h1 v-if=“ok”>Yes</h1>
也可以用v-else 添加else 块
<template> 中 v-if条件组
因为v-if 是一个指令,需要将它添加到一个元素上,但是如果我们想切换多个元素呢可以把一个<template>
元素当做包装元素,并在上面使用v-if,最终的渲染结果不会包括它。
<template>
<h1>Title</h1>
<p>Paragraph 1</p>
<p>Paragraph 2</p>
</template>
v-else
可以用v-else 指令给v-if 添加一个else 块
<div v-if="Math.random() > 0.5">
Sorry
</div>
<div v-else>
Not sorry
</div>
v-else 元素必须紧跟在v-if元素或者v-else-if 的后面 否则它不能被识别。
v-else-if
作用 v-if 的else-if 块,可以链式的多次使用
<div v-if="type ==='A'">
A
</div>
<div v-else-if="type ==='B'">
B
</div>
<div v-else-if="type ==='C'">
C
</div>
<div v-else>
Not A/B/C
</div>
v-else-if必须跟在v-if或者v-else-if之后
使用key控制元素的可重用
vue提供一种方式让你可以自己决定是否要复用元素,你要做的是添加一个属性key ,key 必须带有唯一的值。
<template v-if="loginType === 'username'">
<label>Username</label>
<input placeholder="Enter your username" key="username-input">
</template>
<template v-else>
<label>Email</label>
<input placeholder="Enter your email address" key="email-input">
</template>
<label> 元素仍然会被复用,因为没有添加了key 属性
v-show
v-show 的元素会始终渲染并保持在DOM 中v-show 是简单的切换元素的css 属性display
v-show 不支持<template>语法
七,列表渲染
v-for
用v-for 指令根据一组数组的选项列表进行渲染,v-for 指令需要以 item in items 形式的特殊语法
items 是源数组并且 item 是数组元素迭代的别名。
基本用法
<ul id="example-1">
<li v-for='item in items'>{{item.message}}</li>
</ul>
var example1 = new Vue({
el:'#example-1',
data: {
items: [
{message:'Foo'},
{message:'Bar'}
]
}
})
结果:
Foo
Bar
v-for 块中 ,我们拥有对父作用域属性的完全访问权限。
<ul id="example-2">
<li v-for="(item,index) in items">
{{parentMessage}} - {{ index }} - {{ item.message }}
</li>
</ul>
var example2 = new Vue({
el: '#example -2',
data: {
parentMessage: 'Parent',
items: [
{message: 'Foo'},
{message: 'Bar'}
]
}
})
结果:
Parent - 0 -Foo
Parent - 1 - Bar
也可以用 of 替代 in 作为分隔符,因为它是最接近 JavaScript 迭代器的语法:
<div v-for="item of items"></div>
Template v-for
如同 v-if 模板,你也可以用带有v-for 的<template> 标签来渲染多个元素块
<ul>
<template v-for="item in items">
<li>{{ itme.msg}}</li>
<li class="divider"></li>
</template>
</ul>
对象迭代 v-for
也可以用v-for 通过一个对象的属性来迭代
<ul id="repeat-object">
<li v-for="value in object">
{{value}}
</li>
</ul>
new Vue({
el: ‘#repeat-object’,
data: {
object: {
FirstName: 'John',
LastName: 'Doe',
Age: 30
}
}
})
结果:
John
Doe
30
也可以提供第二个的参数为键名:
<div v-for="(value,key) in object">
{{ key}} : {{ value }}
</div>
第三个参数为索引
<div v-for="(value,key,index) in object">
{{ key }} ,{{key}} ,{{ value }}
</div>
整数迭代 v-for
v-for 也可以取整数,在这种情况下,它将重复多次模板
<div>
<span v-for="n in 10">{{n}} </span>
</div>
组件 和v-for
在自定义数组里,你可以想任何普通元素一样使用v-for
<my-component v-for="item in items"></my-component>
然而他不能自动传递传递数据到组件里,因为组件有自己独立的作用域,为了传递数据到组件里,我们要用props.
<my-component v-for="(item, index) in items" v-bind:item="item" v-bind:index="index">
</my-component>
key
为了给vue 一个提示,以便它跟踪每个节点的身份,从而重用和重新排序现有元素,你需要为,每一项
提供一个唯一key 属性,理想的key 值是每一项都有唯一id ,它的工作方式类似于一个属性,所以你需要v-bvind 来绑定动态值。
<div v-for="item in items" :key="item.id"></div>
建议尽可能使用 v-for 来提供 key ,除非迭代 DOM 内容足够简单,或者你是故意要依赖于默认行为来获得性能提升。
数组更新检测
变异方法
vue包含一组观察数组的变异方法,所以我们将会触发视图更新,这些方法如下。
push() pop() shift() unshift() splice()
sort() reverse()
重塑数组
变异方法会改变原始的数组,也有非变异方法,如:filter(),concat().slice(),这些不会改变原始数组,但是总是返回一个新数组,使用非变异方法的时候,可以用新数组变异方法时,可以用新数组替换久数组。
example1.items = example1.items.filter(function (item) {
return item.message.match(/Foo/)
})
显示过滤/ 排序结果
想要显示一个数组的过滤或排序副本,而不时间改变或重置原始数据,可以创建过滤或排序数组的计算属性。
<li v-for="n in evenNumbers">{{ n }}</li>
data: {
numbers: [1,2,3,4,5]
},
computed: {
evenNumbers: function() {
evenNumbers: function(){
return this.numbers.filter(function (number){
return number % 2 ===0
})
}
}
}
可以在计算属性不合适的情况下(列如,在嵌套 v-for 循环中) 使用method方法:
<li v-for="n in even(number)">{{ n }}</li>
data: {
numbers: [1,2,3,4,5]
},
methods: {
even: function(unmbers) {
return numbers.filter(function(number){
return number % 2 === 0
})
}
}
VUE 入门基础(6)的更多相关文章
- Vue学习记录第一篇——Vue入门基础
前面的话 Vue中文文档写得很好,界面清爽,内容翔实.但文档毕竟不是教程,文档一上来出现了大量的新概念,对于新手而言,并不友好.个人还是比较喜欢类似于<JS高级程序设计>的风格,从浅入深, ...
- Vue入门基础
前面的话 Vue中文文档写得很好,界面清爽,内容翔实.但文档毕竟不是教程,文档一上来出现了大量的新概念,对于新手而言,并不友好.个人还是比较喜欢类似于<JS高级程序设计>的风格,从浅入深, ...
- vue入门基础知识点测试
vue入门基础知识点测试 1.文本(值绑定){{var}}----控制<div></div>的值显示当前时间,且1秒更新一次.(可查阅 setinterval 函数,时间Dat ...
- Vue入门基础(火柴)
前言 由于个人十分欣赏博友——小火柴的蓝色理想,他的博文我看了大多数,觉得十分的精彩,然而很多都是看后即忘.我想除了没有经常动手敲代码,更可能是在看的时候忽略了很多细节,因此打算把他的博文通通给“抄袭 ...
- VUE 入门基础(8)
十,组件 使用组件 注册 可以通过以下这种方式创建一个Vue实例 new Vue({ el: '#some-element', }) 注册一个全局组件,你可以使用Vue.component(tagNa ...
- VUE 入门基础(7)
八,事件处理器 监听事件 可以用v-on 指令监听DOM 事件来触发一些javaScript <div id="example-1"> <button v-on: ...
- VUE 入门基础(4)
四,计算属性 基础例子 <div id='example'> <p>0riginal message: "{{message}}"</p> &l ...
- 02 . Vue入门基础之条件渲染,列表渲染,事件处理器,表单控件绑定
vue基础 声明式渲染 Vue.js 的核心是一个允许采用简洁的模板语法来声明式地将数据渲染进 DOM 的系统 Example1 <!DOCTYPE html> <html> ...
- VUE 入门基础(9)
十一,深入响应式原理 声明响应式属性 由于Vue不允许动态添加根级响应式属性,所以你必须在初始化实例钱声明根级响应式属性,哪怕只有一个空值. var vm = new Vue({ data:{ // ...
随机推荐
- Visual Studio Team System 2008 Team Suite(90 天试用版)
安装完成后,在“控制面板”中启动“添加删除程序”,选中Vs2008,点击“更改.删除”,输入序列号:PYHYP-WXB3B-B2CCM-V9DX9-VDY8T
- Windows下: RubyMine + Ruby On Rails + mysql 搭建开发环境
最近在接手一个手机项目.在搭建环境的过程中,遇到了一些问题,在下文中已做记录,并奉上个人的解决方案. 开发环境 win2003 ; JetBrains RubyMine6.3.3 1. 下载最新版 ...
- 解决Shiro注解无效的问题
当Shiro集成到Spring mvc中,却发现shiro的权限注解不起作用,官方的配置是要支持注解,只需要将以下代码加到spring 配置文件中即可: <bean class="or ...
- NAT 网络地址转换
NAT 网络地址转换(Network Address Translation) NAT(Network Address Translation,网络地址转换)是1994年提出的. 属接入广域网(WA ...
- 【学】jQuery的源码思路4——增加一些功能
本文说一些简单的jQuery实现原理 eq() get() hide() show() index() find() //返回找到的一组元素中的第n个 zQuery.prototype.eq=func ...
- Django 之 ForeignKey、ManyToMany的访问方式
1.ForeignKey 情况I: from django.db import models class Blog(models.Model): pass class Entry(models.Mod ...
- 学习indy组件之一idhttp的使用方法
登录 注册 百度首页 新闻 网页 贴吧 知道 音乐 图片 视频 地图 百科 文库 经验 搜索答案我要提问 首页 分类 公社 知道行家 问医生 高质量问答 经验 个人中心手机知道开放平台 关于del ...
- insertAdjacentHTML方法示例
添加HTML内容与文本内容以前用的是innerHTML与innerText方法,最近发现还有insertAdjacentHTML和insertAdjacentText方法,这两个方法更灵活,可以在指定 ...
- win8.1中EZDML输入中文显示问号问题
在win8.1下使用EZDML,发现无法输入中文,解决办法如下: 打开控制面板--语言 删除美式键盘 然后就可以正常输入中文了 其实就是win8.1把美式键盘默认放在中文语言中,导致的输入问题 ...
- 怎样安装Ubuntu操作系统
(转载自:http://jingyan.baidu.com/article/ff42efa9423991c19e22020d.html) 准备工作 1. 一台普通电脑(装没装操作系统无所谓),保证电脑 ...