本文介绍了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
相关文章:
建站之星导航菜单设置与功能模块配置全攻略
建站之星微信建站一键生成小程序+多端营销系统
在线制作视频网站免费,都有哪些好的动漫网站?
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
如何用IIS7快速搭建并优化网站站点?
如何在宝塔面板中创建新站点?
如何选择服务器才能高效搭建专属网站?
如何在IIS中新建站点并解决端口绑定冲突?
如何用低价快速搭建高质量网站?
网站图片在线制作软件,怎么在图片上做链接?
SQL查询语句优化的实用方法总结
建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析
如何批量查询域名的建站时间记录?
建站之星手机一键生成:多端自适应+小程序开发快速建站指南
如何在景安服务器上快速搭建个人网站?
非常酷的网站设计制作软件,酷培ai教育官方网站?
Python如何创建带属性的XML节点
广州顶尖建站服务:企业官网建设与SEO优化一体化方案
建站之星代理如何获取技术支持?
如何在建站之星绑定自定义域名?
保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?
广州建站公司哪家好?十大优质服务商推荐
如何通过虚拟主机快速完成网站搭建?
如何在腾讯云免费申请建站?
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
如何确认建站备案号应放置的具体位置?
如何高效生成建站之星成品网站源码?
如何基于云服务器快速搭建个人网站?
招贴海报怎么做,什么是海报招贴?
为什么Go需要go mod文件_Go go mod文件作用说明
如何挑选优质建站一级代理提升网站排名?
建站之星3.0如何解决常见操作问题?
网站设计制作公司地址,网站建设比较好的公司都有哪些?
如何快速生成专业多端适配建站电话?
魔毅自助建站系统:模板定制与SEO优化一键生成指南
香港服务器如何优化才能显著提升网站加载速度?
制作证书网站有哪些,全国城建培训中心证书查询官网?
Python多线程使用规范_线程安全解析【教程】
电商网站制作公司有哪些,1688网是什么意思?
学校为何禁止电信移动建设网站?
如何在阿里云ECS服务器部署织梦CMS网站?
如何在Golang中指定模块版本_使用go.mod控制版本号
Thinkphp 中 distinct 的用法解析
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
打鱼网站制作软件,波克捕鱼官方号怎么注册?
再谈Python中的字符串与字符编码(推荐)
C#怎么创建控制台应用 C# Console App项目创建方法
如何快速生成ASP一键建站模板并优化安全性?
小程序网站制作需要准备什么资料,如何制作小程序?
建站主机是否等同于虚拟主机?
*请认真填写需求信息,我们会在24小时内与您取得联系。