- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章vue绑定class的三种方法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
1
2
3
4
5
6
7
8
9
10
11
|
<
div
id
=
"app"
>
<
div
:class
=
"{'active':isActive}"
></
div
>
</
div
>
<
script
>
var app = new Vue({
el:'#app',
data:{
isActive:true
}
})
</
script
>
|
最终渲染结果:
1
|
<
div
class
=
"active"
></
div
>
|
1
2
3
4
5
6
7
8
9
10
11
12
|
<
div
id
=
"app"
>
<
div
class
=
"static"
:class
=
"{'active':isActive,'error':isError}"
></
div
>
</
div
>
<
script
>
var app = new Vue({
el:'#app',
data:{
isActive:true,
isError:false
}
})
</
script
>
|
最终渲染结果(当数据isActive或isError变化时,对应的class也会更新):
1
|
<
div
class
=
"static active"
></
div
>
|
3、当:class的表达式过长或逻辑复杂时,还可以绑定一个计算属性,这是一种友好和常见的用法,一般当条件多于两个时,都可以使用data或者computed,例如:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
<
div
id
=
"app"
>
<
div
:class
=
"classes"
></
div
>
</
div
>
<
script
>
var app = new Vue({
el:'#app',
data:{
isActive:true,
isError:null
},
computed:{
classes(){
return {
active:this.isActive && !this.error,
'text-fail':this.error && this.error.type ==='fail'
}
}
}
})
</
script
>
|
除了计算属性,也可以直接绑定一个Object类型的数据,或者使用类似计算属性的methods. 。
1
2
3
4
5
6
7
8
9
10
11
12
|
<
div
id
=
"app"
>
<
div
:class
=
"[atvieCls,errorCls]"
></
div
>
</
div
>
<
script
>
var app = new Vue({
el:'#app',
data:{
atvieCls:'active',
errorCls:'error'
}
})
</
script
>
|
渲染后的结果为:
1
|
<
div
class
=
"active error"
></
div
>
|
1
2
3
4
5
6
7
8
9
10
11
12
13
|
<
div
id
=
"app"
>
<
div
:class
=
"[isActive ? activeCls : '',errorCls]"
></
div
>
</
div
>
<
script
>
var app = new Vue({
el:'#app',
data:{
isActive:true,
atvieCls:'active',
errorCls:'error'
}
})
</
script
>
|
渲染后的结果为:
1
|
<
div
class
=
"active error"
></
div
>
|
1
2
3
4
5
6
7
8
9
10
11
12
|
<
div
id
=
"app"
>
<
div
:class
=
"[{'active':isActive},errorCls]"
></
div
>
</
div
>
<
script
>
var app = new Vue({
el:'#app',
data:{
isActive:true,
errorCls:'error'
}
})
</
script
>
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
<
div
id
=
"app"
>
<
button
:class
=
"classes"
></
button
>
</
div
>
<
script
>
var app = new Vue({
el: '#app',
data: {
size: 'large',
disabled: true
},
computed: {
classes: function () {
return [
'btn',
{
['btn-'+this.size]: this.size!=='',
['btn-disabled']: this.disabled,
}
]
}
}
})
</
script
>
|
渲染后的结果为:
1
|
<
div
class
=
"btn btn-large btn-disabled"
></
div
>
|
以上,样式btn会始终应用,当数据size不为空时,会应用样式前缀btn-,后加size的值;当数据disabled为真时,会应用样式btn-disabled. 。
使用计算属性给元素动态设置类名,在业务中经常用到,尤其是在写复用的组件时,所以在开发过程中,如果表达式较长或逻辑复杂,应该尽可能优先使用计算属性.
如果直接在自定义组件上使用class或:class,样式规则会直接应用到这个组件的根元素上,例如声明一个简单的组件:
1
2
3
4
5
|
<
script
>
Vue.component('my-component', {
template: '<
p
class
=
"article"
>一些文本</
p
>'
})
</
script
>
|
然后在调用该组件时,使用对象语法或数组语法给组件绑定class,以对象语法为例:
1
2
3
4
5
6
7
8
9
10
11
|
<
div
id
=
"app"
>
<
my-component
:class
=
"'active':isActive"
></
my-component
>
</
div
>
<
script
>
var app = new Vue({
el: '#app',
data: {
isActive: true
}
})
</
script
>
|
最终组件渲染后的结果为:
1
|
<
p
class
=
"article active"
>一些文本</
p
>
|
这种方法仅适用于自定义组件的最外层是一个根元素,否则会无效,当不满足这种条件或需要给具体的子元素设置类名时,应当使用组件的 props 来传递.
以上就是vue绑定class的三种方法的详细内容,更多关于vue绑定class的资料请关注我其它相关文章! 。
原文链接:https://www.cnblogs.com/laiylm/p/12444771.html 。
最后此篇关于vue绑定class的三种方法的文章就讲到这里了,如果你想了解更多关于vue绑定class的三种方法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我只想知道它们之间的区别: .class .class{ font-size:14px; } 对比: .class > .class{ font-size:14px; } 是一样的东西吗? 最佳答案
PrimeFaces 文档的以下摘录使标题中描述的两个选择器之间似乎存在差异: .ui-widget, .ui-widget .ui-widget { font-size: 90% !imp
我正在尝试选择特定值。但我遇到了一个问题。 我有两个元素,一个有 X Y,另一个有 X Y Z。 当选择 X Y Z 时,我也收到 X Y 的值...有没有办法让它寻找 X AND Y AND Z 而
.class.class 和 .class .class 有什么区别? 最佳答案 .class .class 匹配类 .class 的任何元素,这些元素是类 .class< 的另一个元素的后代/. .
我正在研究 Classname.class 和 Classname.class.toString() 并发现了一些不寻常的东西。 .class 在同一个类上运行时似乎等同于 .class。尽管 .cl
我试图在Dart中扩展列表并在此列表中使用另一个类。 这是我的示例,其中注释出了问题: import "Radio.dart"; // extends ListBase { List ra
我有一个很大的“经理”类,我认为它做得太多了,但我不确定如何将它划分为更多逻辑单元。 一般来说类主要由以下方法组成: class FooBarManager{ GetFooEntities();
我在一个文件中定义了一个抽象父类(super class),在另一个文件中定义了一个子类。我需要父类(super class)文件和堆栈跟踪报告来找到一个包含它。 但是,当它到达“extends”行时
我在 A. Alexenderscu 的现代 C++ 设计中找到了一些模板示例 作者使用以下行的地方 template class CheckingPolicy // class SmartPt
看一下这段代码: public static class A { public void doA() { } } public static class B extends A {
我有两个具有 .body 类的 div,但是,一个位于另一个具有 .box 类的 div 中 - 如下所示: 我只想为 .box 内部的 .body 设置样式...但我在下面所
我一定是遗漏了 C++ 规范中的某些内容,因为我无法解释为什么以下代码可以成功编译: class MyClass { static void fun(); }; int main() { MyClas
我正在尝试在 python 中“模拟”命名空间。我使用内部和外部类层次结构来创建我的命名空间。例如,您希望将文件(如资源)的路径保存在一个位置。我试过这样的事情: src = #path to sou
在试验 online crystal compiler 时(这太棒了),我遇到了一个我似乎无法找到解释的错误: class Person class Current < self end
在查看我的一段代码时,我陷入了如下的一条语句。 TMyObjectClass = TMyObject 类; 我有点困惑,不知道这句话是什么意思。由于 TMyObjectClass 在该语句上方没有声明
我正在编写一个简单的应用程序,以学习一些基本的Dart编程,但无法弄清楚其结构和包含的内容-我得到了一个重复的类Point 首先,我有一个叫做MouseTrack的主类。它将初始化列表并产生循环。 #
在 org.springframework.core.SerializableTypeWrapper (版本 5.2.3),第 112 行有以下代码: if (GraalDetector.in
我希望将鼠标悬停在子导航中的列表项上,以激活页面上该类别中所有项的类(不仅仅是父元素或同级元素)。有任何想法吗?这是我的意思的一个例子: img.BLUE {border:1px solid #FF
我正在通过 ClassLoader 加载类: Class clazz = urlClassLoader.loadClass(name.substring(0, name.length() - 6).r
以下简化的类在从 get() 返回值时执行不同的操作,具体取决于该类是被赋予 double 值还是数组作为模板参数: #include "array" #include "type_traits" t
我是一名优秀的程序员,十分优秀!