本文介绍了Vue的Class与Style绑定,分享给大家,具体如下:

绑定 HTML Class
对象语法
我们可以传给 v-bind:class 一个对象,以动态地切换 class:
<style>
.exp{
border: 1px solid #ccc;
}
.forExp{
background: blue;
}
</style>
<div class="exp" v-bind:class="{newExp:isNewExp}"></div>
<script>
var exp=new Vue({
el:".exp".
data:{
isForExp:false
}
})
</script>
如上,我们先给 .exp 一个边框,我们利用 v-bind 方法传入一个新的 class 属性 .newExp,设置一个蓝色的背景颜色。当我们在控制台修改 .newExp 的属性为 true 时,会给 div 添加一个蓝色的背景颜色。
我们也可以传入更多的属性来切换多个 class 。
<div class="exp" v-bind:class="{newExp:isExp,npc:isNpc}"></div>
<script>
data:{
isExp:false,
isNpc:true
}
</script>
在模板里的渲染结果为:
<div class="exp isNpc"></div>
我们也可以使用对象的方法来切换属性
<div class="exp" v-bind:class="obj"></div>
<script>
data:{
obj:{
newExp:false,
npc:true
}
}
</script>
渲染结果和上面的一样
数组语法
我们可以把一个数组传给 v-bind:class,以应用一个 class 列表:
<div class="exp" v-bind:class="[newExp,oldExp]"></div>
<script>
data:{
newExp:"new",
oldExp:"old"
}
</script>
渲染为:
<div class="exp new old"></div>
要切换class,使用三元运算符:
<div class="exp" v-bind:class="[act? newExp:oldExp]"></div>
<script>
data{
newExp:"new",
oldExp:"old",
act:true
}
<script>
act 为 true 时,添加 new ,为 false 时添加 old。
用在组件上
声明一个组件:
Vue.component("my", {
template: '<p class="foo bar">Hi</p>'
})
然后在使用它的时候添加一些 class:
<my class="tip"></my>
最终渲染为
<p class="foo bar tip">Hi</p>
同样的适用于绑定 HTML class:
<my v-bind:class="{ active: isActive }"></my>
当active为true时,HTML 将被渲染成为:
<p class="foo bar active">Hi</p>
绑定内联样式
对象语法
v-bind:style 的对象语法十分直观——看着非常像 CSS,其实它是一个 JavaScript 对象。 CSS 属性名可以用驼峰式 (camelCase) 或 (配合引号的) 短横分隔命名 (kebab-case):
<div v-bind:style="{ color: activeColor, fontSize: fontSize + 'px' }"></div>
<script>
data:{
activeColor:"blue",
fontSize:20
}
</script>
使用对象语法的话,会看起来更加清晰
<div v-bind:style="obj"></div>
<script>
data:{
obj:{
color:"#FFF",
fontSize:"20px"
}
}
</script>
数组语法
v-bind:style 的数组语法可以将多个样式对象应用到一个元素上:
<div v-bind:style="[style1,style2]"></div>
<script>
data:{
style1:{
color:"#666"
},
style2:{
background:"#b1b1b1"
}
}
</script>
自动添加前缀
当 v-bind:style 使用需要特定前缀的 CSS 属性时,如 transform,Vue.js 会自动侦测并添加相应的前缀。
Chrome 和 Safari : -webkit- IE : -ms- Firfox : -moz- Opera : -o-
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# vue.js
# 添加class
# vue绑定style
# class
# 详解vue.js之绑定class和style的示例代码
# vue.js绑定class和style样式(6)
# 学习vue.js中class与style绑定
# vue.js学习笔记之绑定style样式和class列表
# vue.js入门教程之绑定class和style样式
# 绑定
# 多个
# 我们可以
# 看着
# 可以用
# 适用于
# 它是
# 给大家
# 将被
# 可以使用
# 当我们
# 会给
# 用在
# 方法来
# 大家多多
# 先给
# 运算符
# background
# div
# blue
相关文章:
潍坊网站制作公司有哪些,潍坊哪家招聘网站好?
建站主机无法访问?如何排查域名与服务器问题
如何确保西部建站助手FTP传输的安全性?
网站制作知乎推荐,想做自己的网站用什么工具比较好?
,购物网站怎么盈利呢?
北京的网站制作公司有哪些,哪个视频网站最好?
c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】
建站之星收费标准详解:套餐费用及年费价格表一览
如何用狗爹虚拟主机快速搭建网站?
潮流网站制作头像软件下载,适合母子的网名有哪些?
如何选择适配移动端的WAP自助建站平台?
建站之星安装提示数据库无法连接如何解决?
网站代码制作软件有哪些,如何生成自己网站的代码?
专业公司网站制作公司,用什么语言做企业网站比较好?
三星网站视频制作教程下载,三星w23网页如何全屏?
小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
如何在阿里云部署织梦网站?
南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?
测试制作网站有哪些,测试性取向的权威测试或者网站?
建站10G流量真的够用吗?如何应对访问高峰?
制作旅游网站html,怎样注册旅游网站?
西安大型网站制作公司,西安招聘网站最好的是哪个?
如何在建站之星绑定自定义域名?
高防服务器租用指南:配置选择与快速部署攻略
正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?
网站微信制作软件,如何制作微信链接?
全景视频制作网站有哪些,全景图怎么做成网页?
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
如何在Windows环境下新建FTP站点并设置权限?
网站制作网站,深圳做网站哪家比较好?
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
网站按钮制作软件,如何实现网页中按钮的自动点击?
如何确认建站备案号应放置的具体位置?
如何在云指建站中生成FTP站点?
javascript中对象的定义、使用以及对象和原型链操作小结
单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?
C#如何在一个XML文件中查找并替换文本内容
中山网站制作网页,中山新生登记系统登记流程?
建站之星代理如何获取技术支持?
网站制作的方法有哪些,如何将自己制作的网站发布到网上?
如何快速上传建站程序避免常见错误?
海南网站制作公司有哪些,海口网是哪家的?
php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】
表情包在线制作网站免费,表情包怎么弄?
c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】
云南网站制作公司有哪些,云南最好的招聘网站是哪个?
建站主机选哪家性价比最高?
如何选择靠谱的建站公司加盟品牌?
*请认真填写需求信息,我们会在24小时内与您取得联系。