特点
1.JavaScript框架
2.简化DOM操作
3.响应式数据驱动
格式与作用范围
格式
html:
<div id="app">
{{ message }}
</div>
js:
var app = new Vue({
el:"#app",
data:{
message:"黑马程序员",
array:[],
obj:{},
}
})
作用范围
1.Vue实例的作用范围是什么呢?
Vue会管理el选项命中的元素及其内部的后代元素
2.是否可以使用其他的选择器?
可以使用其他的选择器,但是建议使用ID选择器
3.是否可以设置其他的dom元素呢?
可以使用其他的双标签,不能使用HTML和BODY
应用:vue指令,获取元素,操纵他们
指令
v-text
1.设置标签的文本值(textContent)
2.默认写法会替换全部内容,使用差值表达式{{}}可以替换指定内容
3.内部支持写表达式
html:
<div id="app">
<h2 v-text="message+’!’"></h2>
<h2>深圳{{ message + "! "}}</h2>
</div>
js:
var app = new Vue({
el:"#app",
data:{
message:"黑马程序员"
}
})
v-html
1.设置元素的innerHTML
2.内容中有html结构会被解析为标签
3.v-text指令无论内容是什么,只会解析为文本
4.解析文本使用v-text,需要解析html结构使用v-html
html:
<div id="app">
<p v-html=“content"></p>
</div>
js:
var app = new Vue({
el:"#app",
data:{
// content:"黑马程序员"
content:"<a href='#'>黑马程序员</a>"
}
})
v-on
1.v-on指令的作用是:为元素绑定事件
2.事件名不需要写on
3.指令可以简写为@
4.绑定的方法定义在methods属性中
5.方法内部通过this关键字可以访问定义在data中数据
6.事件绑定的方法写成函数调用的形式,可以传入自定义参数
7.定义方法时需要定义形参来接收传入的实参
8. 事件的后面跟上 .修饰符 可以对事件进行限制
9. .enter 可以限制触发的按键为回车
10.事件修饰符有多种
html:
<div id="app">
<input type="button" @click="doIt(p1,p2)" />
<input type="text" @keyup.enter="sayHi">
</div>
js:
var app = new Vue({
el: "#app",
methods: {
doIt: function(p1,p2) {},
sayHi:function(){}
}
})
v-show
1.根据真假切换元素的显示状态
2.原理是修改元素的display,实现显示隐藏
3.指令后面的内容,最终都会解析为布尔值
4.值为true元素显示,值为false元素隐藏
5.数据改变之后,对应元素的显示状态会同步更新
html:
<div id="app">
<img src="地址" v-show="true">
<img src="地址" v-show=“isShow">
<img src="地址" v-show=“age>=18">
</div>
js:
var app = new Vue({
el:"#app",
data:{
isShow:false,
age:16
}
})
v-if
1.根据表达式的真假切换元素的显示状态
2.本质是通过操纵dom元素来切换显示状态
3.表达式的值为true,元素存在于dom树中,为false,从dom树中移除
4.频繁的切换v-show,反之使用v-if,前者的切换消耗小
html:
<div id="app">
<p v-if="true">我是一个p标签</p>
<p v-if="isShow">我是一个p标签</p>
<p v-if="表达式">我是一个p标签</p>
</div>
js:
var app = new Vue({
el:"#app",
data:{
isShow:false
}
})
v-bind
1.为元素绑定属性
2.完整写法是 v-bind:属性名
3.简写的话可以直接省略v-bind,只保留 :属性名
4.需要动态的增删class建议使用对象的方式
html:
<div id="app">
<img :src= "imgSrc" >
<img :title="imgtitle+’!!!!’">
<img :class="isActive?'active':‘’”>
<img :class="{active:isActive}">
</div>
js:
var app = new Vue({
el:"#app",
data:{
imgSrc:"图片地址",
imgTitle:"黑马程序员",
isActive:false
}
})
v-for
1.根据数据生成列表结构
2.数组经常和v-for结合使用
3.语法是( item,index ) in 数据
4.item 和 index 可以结合其他指令一起使用
5.数组长度的更新会同步到页面上,是响应式的
html:
<div id="app">
<ul>
<li v-for="(item,index) in arr" :title="item">
{{ index }}{{ item }}
</li>
<li v-for="(item,index) in objArr">
{{ item.name }}
</li>
</ul>
</div>
js:
var app = new Vue({
el: "#app",
data: {
arr: [1, 2, 3, 4, 5],
objArr: [
{ name: "jack" },
{ name: "rose" }
]
}
})
v-model
1.v-model指令的作用是便捷的设置和获取表单元素的值(获取用户输入、添加到表单中)
2.绑定的数据会和表单元素值相关联
3.绑定的数据←→表单元素的值