大家好,又见面了,我是你们的朋友全栈君。
Vue样式处理
一、class
我们首先来看下class属性的使用。
1.基本的class使用
我们先来看下非vue情况的class的使用,如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<script src="./lib/vue-2.4.0.js"></script>
<style>
.red {
color: red;
}
.thin {
font-weight: 200;
}
.italic {
font-style: italic;
}
.active {
letter-spacing: 0.5em;
}
</style>
</head>
<body>
<div id="app">
<h1 class="red thin">vue中的样式设置1</h1>
</div>
<script>
var vm = new Vue({
el:"#app",
data:{
},
methods:{
}
})
</script>
</body>
</html>
效果
2.绑定数组
效果
3.三目运算
在绑定的数组中我们还可以通过三目运算来实现简单的逻辑,如下
效果如下:
通过效果也可以看出来随着flag的改变,效果也不一样咯~
4.数组中使用对象
上面例子中的三目运算符我们可以替换为对象,效果是一样的。
效果
5.绑定数组
上面都是将数据和view写在一块了,我们也可以将数据直接写在vm中,如下:
效果演示:
通过演示也可以看到,通过绑定对象也是可以的。完整代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<script src="./lib/vue-2.4.0.js"></script>
<style>
.red {
color: red;
}
.thin {
font-weight: 200;
}
.italic {
font-style: italic;
}
.active {
letter-spacing: 0.5em;
}
</style>
</head>
<body>
<div id="app">
<!--基本使用-->
<h1 class="red thin">vue中的样式设置1</h1>
<!--通过v-bind 绑定数组 v-bind 可简写为 ':'-->
<h1 v-bind:class="['red','thin']">vue中的样式设置2</h1>
<h1 :class="['red','thin']">vue中的样式设置3</h1>
<!--绑定的数组中添加 三目逻辑-->
<h1 :class="['red','thin',flag?'active':'']">vue中的样式设置4</h1>
<!--绑定的数组使用对象-->
<h1 :class="['red','thin',{'active':flag}]">vue中的样式设置5</h1>
<!--绑定一个vm中的对象-->
<h1 :class="classObj">vue中的样式设置6</h1>
</div>
<script>
var vm = new Vue({
el:"#app",
data:{
flag:true,
classObj:{red:true,thin:true,italic:false,active:false}
},
methods:{
}
})
</script>
</body>
</html>
二、style
我们除了可以通过使用class来引用样式外,我们还可以通过style来直接指定样式,Vue也支持此操作,具体如下:
单个style引用
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<script src="./lib/vue-2.4.0.js"></script>
</head>
<body>
<div id="app">
<!-- 对象就是无序键值对的集合 -->
<h1 :style="styleObj1">这是一个h1</h1>
</div>
<script>
// 创建 Vue 实例,得到 ViewModel
var vm = new Vue({
el: '#app',
data: {
styleObj1: { color: 'red', 'font-weight': 200 }
},
methods: {}
});
</script>
</body>
</html>
效果
多个style引用
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<script src="./lib/vue-2.4.0.js"></script>
</head>
<body>
<div id="app">
<!-- 对象就是无序键值对的集合 -->
<h1 :style="styleObj1">这是一个h1</h1>
<h2 :style="[ styleObj1, styleObj2 ]">这是一个h2</h2>
</div>
<script>
// 创建 Vue 实例,得到 ViewModel
var vm = new Vue({
el: '#app',
data: {
styleObj1: { color: 'red', 'font-weight': 200 },
styleObj2: { 'font-style': 'italic' }
},
methods: {}
});
</script>
</body>
</html>
效果:
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/106502.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...