在前端开发中,设置元素的 class 列表和内联样式是基本要求。本文主要讲解Vue开发中,样式列表和内联样式的绑定,仅供学习分享使用,如果有不足之处,还请指正。

概述

Vue操作元素的 class 列表和内联样式是数据绑定的一个常见需求。因为它们都是属性,所以我们可以用 v-bind 处理它们:只需要通过表达式计算出字符串结果即可。不过,字符串拼接麻烦且易错。因此,在将 v-bind 用于 class 和 style 时,Vue.js 做了专门的增强。表达式结果的类型除了字符串之外,还可以是对象或数组。

绑定 HTML Class

可以传给 v-bind:class 一个对象,以动态地切换 class:

 <div v-bind:class="{red:isred,bold:isbold}">混合样式1--绑定数据属性</div>

上面的语法表示 red 这个 class 存在与否将取决于数据属性 isred 的 是否为true。你可以在对象中传入更多属性来动态切换多个 class。此外,v-bind:class 指令也可以与普通的 class 属性共存。

绑定的数据对象采用复合样式的效果,不必内联定义在模板里,如下所示:

 <div v-bind:class="multi">混合样式2---复合对象</div>

其中multi是一个复合数据对象,如下所示:

 <script type="text/javascript">
var vm=new Vue({
el:"#app",
data:{
bg:'yellow',
isbold:true,
isred:true,
multi:{
red:true,
bold:true,
}
} });
</script>

以上两种,结果渲染是一样的,如下所示:

 <div class="red bold"></div>

绑定计算属性

我们也可以在这里绑定一个返回对象的计算属性。这是一个常用且强大的模式:

 <div v-bind:class="cmpstyle">混合样式3---计算属性</div>

其中cmpstyle是一个计算属性,返回的对象,如下所示:

 <script type="text/javascript">
var vm=new Vue({
el:"#app",
computed:{
cmpstyle:function(){
return {
red:true,
bold:true,
}
}
}
});
</script>

CSS数组语法

我们可以把一个数组传给 v-bind:class,以应用一个 class 列表:

 <div v-bind:class="arrcss">混合样式4---数组绑定样式</div>

其中arrcss是一个数组样式,如下所示:

 <script type="text/javascript">
var vm=new Vue({
el:"#app",
data:{
arrcss:['red','bold'],
}
});
</script>

绑定内联样式

v-bind:style 的对象语法十分直观——看着非常像 CSS,但其实是一个 JavaScript 对象。CSS 属性名可以用驼峰式 (camelCase) 或短横线分隔 (kebab-case,记得用引号括起来) 来命名:

 <div v-bind:style="{color:bg2}">内联样式2--属性</div>

绑定内联样式,直接绑定到一个样式对象通常更好,这会让模板更清晰:

  <div v-bind:style="bg3">内联样式3--绑定对象</div>

其中,bg3是一个对象,如下所示:

 <script type="text/javascript">
var vm=new Vue({
el:"#app",
data:{
bg2:'green',
bg3:{
color:'red',
fontSize:'30px'
}
}
});
</script>

内联样式数组语法

v-bind:style 的数组语法可以将多个样式对象应用到同一个元素上:

 <div v-bind:style="[bg3,bg4]">内联样式4--绑定对象</div>

多重值

从 2.3.0 起你可以为 style 绑定中的属性提供一个包含多个值的数组,常用于提供多个带前缀的值,例如:

 <div :style="{ display: ['-webkit-box', '-ms-flexbox', 'flex'] }"></div>

这样写只会渲染数组中最后一个被浏览器支持的值。在本例中,如果浏览器支持不带浏览器前缀的 flexbox,那么就只会渲染 display: flex。

本示例中源码如下:

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>一起学Vue之绑定样式</title>
<!-- 开发环境版本,包含了有帮助的命令行警告 -->
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<style type="text/css">
.red{
color:red;
}
.yellow{
color: goldenrod;
}
.green{
color: green;
}
.bold{
font:bolder;
font-style: oblique;
}
</style>
</head>
<body>
<div id="app">
<div v-bind:class="bg">
这是我的颜色
</div>
<!--
作者:Alan.hsiang@qq.com
时间:2019-11-20
描述:Html样式:可以传给 v-bind:class 一个对象,以动态地切换 class:
上面的语法表示 active 这个 class 存在与否将取决于数据属性 isActive 的 是否为true。
-->
<div v-bind:class="{red:isred,bold:isbold}">混合样式1--绑定数据属性</div>
<!--
作者:Alan.hsiang@qq.com
时间:2019-11-20
描述:绑定的数据对象采用复合样式的效果,不必内联定义在模板里
-->
<div v-bind:class="multi">混合样式2---复合对象</div>
<!--
作者:Alan.hsiang@qq.com
时间:2019-11-20
描述:绑定计算属性
-->
<div v-bind:class="cmpstyle">混合样式3---计算属性</div>
<!--
作者:Alan.hsiang@qq.com
时间:2019-11-20
描述:数组绑定样式
--> <div v-bind:class="arrcss">混合样式4---数组绑定样式</div>
<!--
作者:Alan.hsiang@qq.com
时间:2019-11-20
描述:绑定内联样式,直接绑定到一个样式对象通常更好,这会让模板更清晰:
-->
<div v-bind:style="{color:bg2}">内联样式2--属性</div>
<div v-bind:style="bg3">内联样式3--绑定对象</div>
<!--
作者:Alan.hsiang@qq.com
时间:2019-11-20
描述:也可以绑定数组
-->
<div v-bind:style="[bg3,bg4]">内联样式4--绑定对象</div>
</div>
<script type="text/javascript">
var vm=new Vue({
el:"#app",
data:{
bg:'yellow',
isbold:true,
isred:true,
multi:{
red:true,
bold:true,
},
arrcss:['red','bold'],
bg2:'green',
bg3:{
color:'red',
fontSize:'30px'
},
bg4:{
fontStyle:'italic'
}
},
computed:{
cmpstyle:function(){
return {
red:true,
bold:true,
}
}
}
});
</script>
</body>
</html>

备注

不管见识高低,一个人深度整理和收拾自己的内心,这事本身就很迷人。我努力奔跑只为追上曾经被寄予厚望的自己!!!

一起学Vue之样式绑定的更多相关文章

  1. vue的样式绑定

    vue在样式绑定,看这官方的文档,怎么试都不行后来看了一篇文章 <div :class="[rankClass]"></div> <script> ...

  2. Vue 将样式绑定到一个对象让模板更清晰

    Vue 将样式绑定到一个对象让模板更清晰 <div id="app"> <div v-bind:style="styleObject"> ...

  3. vue.js样式绑定

    vue.js样式绑定 class 与 style 是 HTML 元素的属性,用于设置元素的样式,我们可以用 v-bind 来设置样式属性. Vue.js v-bind 在处理 class 和 styl ...

  4. 10.Vue.js 样式绑定

    Vue.js 样式绑定 Vue.js class class 与 style 是 HTML 元素的属性,用于设置元素的样式,我们可以用 v-bind 来设置样式属性. Vue.js v-bind 在处 ...

  5. Vue.js 样式绑定(1)

    demo <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <titl ...

  6. vue.js 样式绑定

    简单用法 <div v-bind:height="bindStyle"> 复杂用法 <div v-bind:style="bindStyle" ...

  7. Vue.js:样式绑定

    ylbtech-Vue.js:样式绑定 1.返回顶部 1. Vue.js 样式绑定 Vue.js class class 与 style 是 HTML 元素的属性,用于设置元素的样式,我们可以用 v- ...

  8. Vue样式绑定、事件绑定

    1.样式绑定 1.1class类标签绑定 <p :class="对象"> <p :class="数组"> <p :class=&q ...

  9. Vue基础语法(样式绑定,事件处理,表单,Vue组件)

    样式绑定 事件处理 表单 Vue组件 样式绑定 <!DOCTYPE html> <html> <head> <meta charset="utf-8 ...

随机推荐

  1. 记一次安卓app上线应用宝

    背景:前几个月开发了一个安卓app(用的是Dcloud公司的uniapp框架),已经成功上线华为应用市场和小米应用市场.之前上线应用宝是因为没有软著,所以一直也没上线.近期甲方又提出了上架应用宝,于是 ...

  2. Java 大小端转换(基于ByteBuffer)

    大小端的基础知识: 小端( little-endian):低位字节在前,高位字节在后.大端( Big-Endian),则反之.具体而言,就是为了说清楚,CPU架构1 字(word)中byte的存储顺序 ...

  3. mysql 安装报错集合

    mysql-5.6.39 源码编译安装报错 报错信息: /tmp/ccV858jD.s: Assembler messages: /tmp/ccV858jD.s: Fatal error: can't ...

  4. 一个null,差点把系统给弄崩溃了

    今天生产上面发现了一个奇异的bug,URL上面会带上一个ID,这个ID是关联别的系统的,类似这种格式 xxx.xxx.xxx.xxx  ,是别的系统自己填写的,我们的URL会带上id=xxx.xxx. ...

  5. Python不再为字符集编码发愁,使用chardet轻松解决你的困扰。

    欢迎添加华为云小助手微信(微信号:HWCloud002 或 HWCloud003),输入关键字"加群",加入华为云线上技术讨论群:输入关键字"最新活动",获取华 ...

  6. milvus安装及其使用教程

    milvus 简介 milvus是干什么的?通俗的讲,milvus可以让你在海量向量库中快速检索到和目标向量最相似的若干个向量,这里相似度量标准可以是内积或者欧式距离等.借用官方的话说就是: Milv ...

  7. JQuery之Ajax应用

    众所周知JQuery中的Ajax主要用于数据传输,其数据传输格式为JSON格式数据,比XML格式数据传输更快. ajax 是 Asynchronous JavaScript and XML的简写,aj ...

  8. 华为OSPF与ACL综合应用

    一. 实验拓扑图 二.实验要求 1.企业内网运行OSPF路由协议,区域规划如图所示:2.财务和研发所在的区域不受其他区域链路不稳定性影响:3.AR1.AR2.AR3只允许被IT登录管理:4.YF和CW ...

  9. Docker系列之常用命令操作手册

    目录 1.安装虚拟机 2.安装Docker 3.Docker镜像操作 4.Docker容器操作 Docker系列之常用命令操作手册 继上一篇博客Docker系列之原理简单介绍之后,本博客对常用的Doc ...

  10. Apple 应用内支付心得

    http://tank2308635.iteye.com/blog/1238687Apple 应用内支付 首先简要说一下IAP 流程 简要步骤说明: 用户进入购买虚拟物品页面,App从后台服务器获取产 ...