今天主要vue的使用
v-if,v-for,v-model,数据双向绑定,处理表单和选框,class与style的常用绑定,v-on等等。
一,数据绑定
1,vue允许采用简洁的模板语法声明式的将数据渲染进DOM
<!DOCTYPE html>
<html>
<head>
<title></title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
<div id="app">{{msg}}</div>
<script type="text/javascript">
new Vue({
el:'#app',
data:{
msg:'hello!'
}
})
</script>
</body>
</html>
页面效果
01.jpg
2,通过数据绑定事件来更改数据从而改变视图
<!DOCTYPE html>
<html>
<head>
<title></title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
<div id="app">{{msg}}
<button :title="msg" @click="changeText">点击</button>
</div>
<script type="text/javascript">
new Vue({
el:'#app',
data:{
msg:'点我有惊喜'
},
methods:{
changeText:function(){
this.msg = "哈哈,上当了吧~"
}
}
})
</script>
</body>
</html>
页面效果:
GIF.gif
二,条件与循环 v-if
v-if指令去控制切换一个元素的显示隐藏
<!DOCTYPE html>
<html>
<head>
<title></title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
<div id="app">
<span v-if="seen">
哈哈,你看不到我~
</span>
</div>
<script type="text/javascript">
new Vue({
el:'#app',
data:{
seen:false
}
})
</script>
</body>
</html>
此时 seen=false,页面上是没有显示任何元素的,但是如果seen=true,那么我们在页面上是可以看到元素内容的。
这个例子演示了我们不仅可以绑定DOM文本到数据,也可以绑定DOM结构到数据。而且,Vue也提供了一个强大的过渡效果系统,可以在Vue插入/更新/删除元素时自动应用过度效果,这个方面,小伙伴可以选择自行进阶学习。
v-for渲染一个项目列表
<!DOCTYPE html>
<html>
<head>
<title></title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
<div id="app">
<div v-for="item in lists">{{item.text}}</div>
</div>
<script type="text/javascript">
new Vue({
el:'#app',
data:{
lists:[
{text:'周杰伦'},
{text:'蔡依林'},
{text:'林俊杰'}
]
}
})
</script>
</body>
</html>
页面效果
03.jpg
三,双向数据绑定
Vue还提供了v-model指令,他能轻松实现表单输入和应用状态之间的双向绑定。
<!DOCTYPE html>
<html>
<head>
<title></title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
<div id="app">
<h1>{{message}}</h1>
<input type="text" v-model="message" name="">
</div>
<script type="text/javascript">
new Vue({
el:'#app',
data:{
message:'hello'
}
})
</script>
</body>
</html>
页面效果
GIF.gif
处理复选框(一)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
<div id="app">
<input type="checkbox" id="checkbox" v-model="checked">
<label for="checkbox">{{ checked }}</label>
</div>
<script type="text/javascript">
var app = new Vue({
el: '#app',
data: {
checked: false
},
})
</script>
</body>
</html>
案例效果
GIF.gif
处理复选框(二)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
<div id="app">
<input type="checkbox" id="food" value="美食" v-model="checked">
<label for="jack">美食</label>
<input type="checkbox" id="view" value="美景" v-model="checked">
<label for="john">美景</label>
<input type="checkbox" id="beau" value="美人" v-model="checked">
<label for="mike">美人</label>
<br>
<span>Checked: {{ checked }}</span>
</div>
<script type="text/javascript">
var app = new Vue({
el: '#app',
data: {
checked: []
},
})
</script>
</body>
</html>
案例效果
GIF.gif单选按钮
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
<div id="app">
<input type="radio" id="one" value="江山" v-model="picked">
<label for="one">江山</label>
<br>
<input type="radio" id="two" value="美人" v-model="picked">
<label for="two">美人</label>
<br>
<span>Picked: {{ picked }}</span>
</div>
<script type="text/javascript">
var app = new Vue({
el: '#app',
data: {
picked:''
},
})
</script>
</body>
</html>
案例效果
GIF.gif下拉选框
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
<div id="app">
<select v-model="selected">
<option disabled value="">请选择</option>
<option>周杰伦</option>
<option>蔡依林</option>
<option>张靓颖</option>
</select>
<span>Selected: {{ selected }}</span>
</div>
<script type="text/javascript">
var app = new Vue({
el: '#app',
data: {
selected:null
},
})
</script>
</body>
</html>
如果 v-model 表达初始的值不匹配任何的选项,<select> 元素就会以”未选中”的状态渲染。在 iOS 中,这会使用户无法选择第一个选项,因为这样的情况下,iOS 不会引发 change 事件。因此,像以上提供 disabled 选项是建议的做法。
案例效果
多项列表(绑定到一个数组)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
<div id="app">
<select v-model="selected" multiple style="width: 50px">
<option>A</option>
<option>B</option>
<option>C</option>
</select>
<br>
<span>Selected: {{ selected }}</span>
</div>
<script type="text/javascript">
new Vue({
el: '#app',
data: {
selected: []
}
})
</script>
</body>
</html>
案例效果
GIF.gif动态选项
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
<div id="app">
<select v-model="selected">
<option v-for="option in options" v-bind:value="option.value">
{{ option.text }}
</option>
</select>
<span>Selected: {{ selected }}</span>
</div>
<script type="text/javascript">
new Vue({
el: '#app',
data: {
selected: 'A',
options: [
{ text: '《七里香》', value: '周杰伦' },
{ text: '《布拉格广场》', value: '蔡依林' },
{ text: '《演员》', value: '薛之谦' }
]
}
})
</script>
</body>
</html>
案例效果
GIF.gifv-on
为了让用户和你的应用进行互动,我们可以用v-on指令绑定一个时间监听器,通过它调用我们Vue实例中定义的方法:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
<div id="app">
<p>{{ message }}</p>
<button v-on:click="reverseMessage">逆转消息</button>
</div>
<script type="text/javascript">
var app = new Vue({
el: '#app',
data: {
message: '时间是一种解药,更是我现在服下的毒药。'
},
methods: {
reverseMessage: function () {
this.message = this.message.split('').reverse().join('')
}
}
})
</script>
</body>
</html>
案例效果
GIF.gif
关于修饰符
.number
如果想自动将用户的输入值转为 Number 类型(如果原值的转换结果为 NaN 则返回原值),可以添加一个修饰符 number 给 v-model 来处理输入值:
<input v-model.number="age" type="number">
.trim
如果要自动过滤用户输入的首尾空格,可以添加 trim 修饰符到 v-model 上过滤输入:
<input v-model.trim="msg">
.lazy
在默认情况下,v-model在input事件中同步输入框的值与数据 (除了 上述IME 部分),但你可以添加一个修饰符lazy,从而转变为在change事件中同步:
<!-- 在 "change" 而不是 "input" 事件中更新 -->
<input v-model.lazy="msg" >
四,class与style的绑定
对象语法
我们可以传给 v-bind:class 一个对象,来动态的切换class。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<style type="text/css">
.active{color: red;}
.danger{color: green;}
</style>
<body >
<div class="static"
v-bind:class="{ active: isActive, 'danger': hasError }" id="app">
时间是一种解药,更是我现在正服下的毒药。。。
</div>
<script type="text/javascript">
new Vue({
el:'#app',
data: {
isActive: true,
hasError: false
}
})
</script>
</body>
</html>
案例效果
04.jpg
当isActive或者hasError变化时,class列表经相应的更新。
根据对象的计算属性,绑定相应的样式。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<style type="text/css">
.active{color: red;}
.text-danger{color: green;}
</style>
<body >
<div v-bind:class="classObject" id="app">
时间是一种解药,更是我现在正服下的毒药。。。
</div>
<script type="text/javascript">
new Vue({
el:'#app',
data: {
isActive: true,
error: false
},
computed: {
classObject: function () {
return {
active: this.isActive && !this.error
}
}
}
})
</script>
</body>
</html>
此案例与上述案例效果同
数组语法
可以把一个数组传给v-bind:class,以应用一个class列表
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="js/vue.js"></script>
</head>
<style type="text/css">
.active{color: red;}
.danger{background: green;}
</style>
<body >
<div v-bind:class="[activeClass, errorClass]" id="app">
时间是一种解药,更是我现在正服下的毒药。。。
</div>
<script type="text/javascript">
new Vue({
el:'#app',
data: {
activeClass: 'active',
errorClass: 'danger'
}
})
</script>
</body>
</html>
05.jpg
当然你也可以根据条件切换列表中的class,可以使用三元表达式,这个也是很常用的
<div v-bind:class="[isActive ? activeClass : '', errorClass]">
华丽的分割线
我是乐观的范小饭,喜欢就点赞,真爱就打赏,地铁口买煎饼果子的时候,可以奢侈的加个蛋~
网友评论