指令
1.v-cloak
不需要表达式
用法:
这个指令保持在元素上直到关联实例结束编译。和 CSS 规则如 [v-cloak] { display: none } 一起用时,这个指令可以隐藏未编译的 Mustache 标签直到实例准备完毕。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
[v-cloak] {
display: none;
}
</style></head>
<body>
<div id="app">
<!--在使用模板语法的标签上添加v-cloak的指令 -->
<p v-cloak>{{msg+1+1+1+1+1}}</p>
</div>
<script src="vue.js"></script>
<script>
//创建一个vue环境,创建一个VM层
let vm = new Vue({
el:'#app',
data:{
msg:'hello world'
}
})
</script>
</body>
</html>
不会显示,直到编译结束。
2.v-text
预期:string
详细:
更新元素的 textContent。如果要更新部分的 textContent,需要使用 {{ Mustache }} 插值。
参考:数据绑定语法 - 插值
<!-- 指令,标签的自定义属性 -->
<div id="app">
<!-- {{userName}} -->
<p v-text='userName'></p>
</div>
<script src="vue.js"></script>
<script>
new Vue({
el:'#app',
data:{
userName:'admin'
}
})
</script>
3.v-html
预期:string
详细:
更新元素的 innerHTML。注意:内容按普通 HTML 插入 - 不会作为 Vue 模板进行编译。如果试图使用 v-html 组合模板,可以重新考虑是否通过使用组件来替代。
参考:数据绑定语法 - 插值
<body>
<div id="app">
<!-- {{myDiv}} -->
<p v-html='myDiv'></p>
</div>
<script src="vue.js"></script>
<script>
new Vue({
el:'#app',
data:{
myDiv:'<h1>HiHiHi</h1>'
}
})
</script>
</body>
4.v-pre
不需要表达式
用法:
跳过这个元素和它的子元素的编译过程。可以用来显示原始 Mustache 标签。跳过大量没有指令的节点会加快编译。
<body>
<div id="app">
<p v-pre>{{msg}}</p>
</div>
<script src="js/vue.js"></script>
<script>
new Vue({
el: '#app',
data: {
msg: '不想被编译'
}
})
</script>
</body>
5.v-once
不需要表达式
详细:
只渲染元素和组件一次。随后的重新渲染,元素/组件及其所有的子节点将被视为静态内容并跳过。这可以用于优化更新性能。
<div id="app">
<p v-once>{{msg}}</p>
</div>
<script src="vue.js"></script>
<script>
new Vue({
el:'#app',
data:{
msg:'最初的梦想:当画家'
},
mounted(){
this.msg = '后来成为了程序猿'
}
})
</script>
6.v-model
预期:随表单控件类型不同而不同。
用法:
在表单控件或者组件上创建双向绑定。细节请看下面的教程链接。
参考:
表单控件绑定
组件 - 在输入组件上使用自定义事件
<!-- 双向数据绑定-->
<div id="app">
<input type="text" value="" v-model="userName">
<p>{{userName}}</p>
</div>
<script src="vue.js"></script>
<script>
new Vue({
el:'#app',
data:{
userName:'admin'
}
})
</script>
7.v-on
缩写:@
预期:Function | Inline Statement | Object
参数:event
用法:
绑定事件监听器。事件类型由参数指定。表达式可以是一个方法的名字或一个内联语句,如果没有修饰符也可以省略。
用在普通元素上时,只能监听原生 DOM 事件。用在自定义元素组件上时,也可以监听子组件触发的自定义事件。
在监听原生 DOM 事件时,方法以事件为唯一的参数。如果使用内联语句,语句可以访问一个 $event property:v-on:click=“handle(‘ok’, $event)”。
参考:
事件处理器
组件 - 自定义事件
<!-- 解放Dom-->
<div id="app">
<input type="text" v-model="num"/><br/>
<input type="button" value="+1" v-on:click='add'/>
<input type="button" value="-1" v-on:click='sub'/>
</div>
<script src="vue.js"></script>
<script>
new Vue({
el:'#app',
data:{
num:1
},
//将num值进行操作
//methods:用来写页面需要的方法的配置项
methods:{
add:function(){
this.num += 1
},
sub(){
this.num -= 1
}
}
})
</script>
8.v-bind
缩写::
预期:any (with argument) | Object (without argument)
参数:attrOrProp (optional)
用法:
动态地绑定一个或多个 attribute,或一个组件 prop 到表达式。
在绑定 class 或 style attribute 时,支持其它类型的值,如数组或对象。可以通过下面的教程链接查看详情。
在绑定 prop 时,prop 必须在子组件中声明。可以用修饰符指定不同的绑定类型。
没有参数时,可以绑定到一个包含键值对的对象。注意此时 class 和 style 绑定不支持数组和对象。
参考:
Class 与 Style 绑定
组件 - Props
组件 - .sync 修饰符
<div id="app">
<img v-bind:src="srcUrl" >
</div>
<script src="vue.js"></script>
<script>
new Vue({
el: '#app',
data: {
srcUrl: './img/1.jpg'
},//这个逗号必须要
mounted() {
//这个this必须要:它只当前的vm实例
this.srcUrl = './img/2.jpg'
}
})
</script>
9.if&show
●用法:
指令用于条件性地渲染一块内容。这块内容只会在指令的表达式返回 truthy 值的时候被渲染。
<div id="app">
<button @click='changeShow'>显示图片</button>
<!-- <div v-if="isShow"></div> -->
<div v-if='isShow'>
<!-- <img src="./img/timg.jpg"> -->
请登录
</div>
<div>
用户:aa已登录
</div>
</div>
<script src="./js/vue.js"></script>
<script>
new Vue({
el: '#app',
data: {
isShow: true//布尔值
},
methods: {
changeShow() {
this.isShow = !this.isShow
}
}
})
</script>
因为 v-if 是一个指令,所以必须将它添加到一个元素上。但是如果想切换多个元素呢?此时可以把一个 元素当做不可见的包裹元素,并在上面使用 v-if。最终的渲染结果将不包含 元素。
<template v-if="ok">
<h1>Title</h1>
<p>Paragraph 1</p>
<p>Paragraph 2</p>
</template>
10.v事件修饰符
<div id="app">
<a href="https://www.baidu.com/" @click.prevent='myAlert'>点击</a>
<!-- 冒泡 -->
<div @click='divC1'>
<button @click.stop='btnC1'>点击</button>
</div>
<!-- 按键的修饰符 -->
<input type="text" v-model='nickName' @keyup='clearTxt'>
<!-- 点亮backspace 直接清空 -->
</div>
<script src="./js/vue.js"></script>
<script>
new Vue({
el: '#app',
data: {
nickName: '字符字符字符字符字符字符字符字符'
},
methods: {
myAlert(e) {
//阻止默认行为
//e.preventDefault();传统
//只专注于自己的操作
alert('被点亮了')
},
divC1() {
console.log('div');
},
btnC1() {
console.log('btn');
},
clearTxt() {
//清空表单
this.nickName = ''
}
}
})
</script>