Vue提供的指令有哪些,用法分别是怎样的
Admin 2022-07-01 群英技术资讯 719 次浏览
这篇文章给大家分享的是Vue提供的指令有哪些,用法分别是怎样的。小编觉得挺实用的,因此分享给大家做个参考,文中的介绍得很详细,而要易于理解和学习,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。v-text
v-html
v-showv-if v-else v-else-if v-for v-on v-bind v-model v-slot
v-pre
v-cloak
v-once注意:代表重要常用的
<p v-text="info"></p>
<p v-text="'abc' + info"></p>
<script>
new Vue({
el: '#app',
data: {
info: 'a'
}
})
</script>
v-text="info"渲染页面结果为a,因为info是个变量,就直接展示变量所对应的值
v-text="'abc' + info"渲染页面结果为abca,当你想用字符串和变量拼接时,可以在字符串上增加单引号,这样程序就认为你这个是个字符串,字符串+info变量最后的结果就是字符串abca
有时候我们的Vue对象中,或者是后台返回给我们一个段原生的html代码,我们需要渲染出来,那么如果直接通过{{}}渲染,会把这个html代码当做字符串。这时候我们就可以通过v-html指令来实现。
示例代码如下:
<p v-html="'<b>ok</b>'"></p> <p v-text="'<b>ok</b>'"></p>
以上两行代码除了用的vue指令不一样以外,没有任何区别,让我们先展示结果吧
ok <b>ok</b>
v-html可以解析html的标签,而text传的是字符串,不用管字符串里面具体的内容是什么,统一都直接展示出原来的字符
只渲染元素和组件一次。随后的重新渲染,元素/组件及其所有的子节点将被视为静态内容并跳过。这可以用于优化更新性能。
<input type="text" v-model="msg" v-once> // 只渲染一次
<p v-once>{{ msg }}</p>
这个指令保持在元素上直到关联实例结束编译。和 CSS 规则如 [v-cloak] { display: none } 一起用时,这个指令可以隐藏未编译的Mustache标签直到实例准备完毕。
跳过这个元素和它的子元素的编译过程。可以用来显示原始 Mustache 标签。跳过大量没有指令的节点会加快编译。
<div id="app">
<span v-pre>{{message}}</span>
</div>
<script>
const app = new Vue({
el: "#app",
data: {
message: "hello"
}
})
</script>
正常来讲我们会通过编译最后在网页上显示hello,但是使用了v-pre指令后,就会跳过编译,直接展示原始的标签内容也就是{{message}}
如果我们想要在html元素的属性上绑定我们Vue对象中的变量,那么需要通过v-bind来实现。
<div id="app">
<a v-bind:href="baidu" rel="external nofollow" >百度</a>
<img :src="imgSrc" alt="">
</div>
<script>
const app = new Vue({
el: "#app",
data: {
message: "hello",
baidu: "https://www.baidu.com",
imgSrc: "https://www.baidu.com/img/pc_a91909218349e60ed8f6f6f226c30e5f.gif"
}
})
</script>
我们只需要在绑定的属性前面添加v-bind:即可,当然我们也可以使用缩写:,直接写冒号即可
绑定Class有2种方式,一种通过数组绑定,一种通过对象绑定
通过对象的方式来实现:
<div id="app">
<p v-bind:class="{color:isColor}">你好,世界</p>
</div>
<script>
const app = new Vue({
el: "#app",
data: {
isColor: true
}
})
</script>
<style>
.color{
color: blue;
}
</style>
对象的方式即像上面的代码{color:isColor} ,key是color,value是isColor,当value的值为true则渲染,为false则不渲染
通过数组的方式来实现:
<div id="app">
<p :class="[classname1, classname2]">{{message}}</p>
</div>
<script>
const app = new Vue({
el: "#app",
data: {
message: "hello",
classname1: "pcolor",
classname2: "fontSize"
},
})
</script>
<style>
.pcolor{
color: red;
}
.fontSize{
font-size: 30px;
}
</style>
当class需要绑定2个属性时,可以使用数组的方式
绑定Style也有2种方式,一种通过数组绑定,一种通过对象绑定
通过对象的方式来实现:
<div id="app">
<p :style="{fontSize:'100px'}">{{message}}</p>
</div>
<script>
const app = new Vue({
el: "#app",
data: {
message: "hello"
}
})
</script>
注意:对象绑定的时候只能驼峰命名法fontSize,不能使用font-size否则会报错,100px加单引号就是字符串,不加则是变量,需要在data中添加变量
通过数组的方式来实现:
<div id="app">
<p :style="[style1, style2]">{{message}}</p>
</div>
<script>
const app = new Vue({
el: "#app",
data: {
message: "hello",
style1: {background:'red'},
style2: {fontSize:'30px'},
}
})
</script>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要给大家分享是JavaScript中的延迟加载属性的内容,下文对延迟加载属性模式有详细的介绍及示例,有这方面学习需要的朋友可以参考,下面我们一起来学习一下。
这篇文章主要介绍了React Diff原理的相关资料,帮助大家更好的理解和学习使用React框架,感兴趣的朋友可以了解下
这篇文章主要为大家介绍了闭包结合递归等于柯里化的原理解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
本篇文章带大家了解一下Node中的文件模块和核心模块,聊聊文件模块的查找和文件模块的编译执行、JavaScript与C/C++ 核心模块的编译执行,希望对大家有所帮助!
在我们做项目中,常见的是横向表格,但是偶尔的需求,也会做竖向的表格。类似于这样的效果图,其实并不一定非得使用UI组件,有的时候使用原生的方式去做
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008