如何在Vue中有条件地使用CSS类

很多时候web在运行时要更改元素的css类名。但是在改变类名时,有时最好是有条件地应用样式。例如你有一个翻页的效果。翻页效果通常有一个高亮的效果,用于向用户显示当前页,这对于用户而言是很有帮助的。该项目的样式是有条件设置的,基于当前正在查看的页面。

本文主要介绍在Vue中有条件地使用CSS类,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。

翻页常见的一个效果看起来像下面这样:

如何在Vue中有条件地使用CSS类

在这个示例中,共有五页,每次只选择其中一个页面。如果你用Bootstrap构建一个分页器,那么所选的页面将有一个名为 active 的CSS类名应用在列表项中。如果页面是当前浏览的页面,那么你希望该类被应用。换句话说,你希望有条件地应用 active 类名。在Vue中,提供了一种方法,可以有条件地将CSS类应用于元素。在接下来的内容中将向大家展示这种技术。

要在运行时有条件地应用CSS类,需要绑定到一个JavaScript对象。要成功完成这个任务,必须完成两个步骤。首先,必须确保定义了CSS类名,然后在模板中创建类绑定。在本文的其他部分,我将详细解释这些步骤。

立即学习“前端免费学习笔记(深入)”;

Step1: 定义你的CSS类名

想象一下,在一段时间内,上面图像中显示的五个页面荐是使用像下面的HTML代码构建的:

  

登录后复制

注意:这个代码片段中每个列表项 li 表示的就是每个页面。改元素引用了 page-item 类名。在这段代码中,使用的是Bootstrap的CSS框架。然而,如果没有定义,那么确保它在某个地方被定义了。不过,第二个CSS类是与本文最相关的类。

active 的CSS类名用于标识当前选定的页面。在本文中,这个CSS类也是在Bootstrap框架中常用的。如上面的代码片段所示, active 类只在第三个列表项元素中使用。你可能会猜到,这是你想有条件地应用的CSS类。要做到这一点,你需要添加一个JavaScript对象。

Step2: 绑定你的CSS类名

让我们重新构建步骤一中的代码。当在模板中创建类绑定时,有两个主要的选择:使用对象语法或使用数组语法。接下来的内容,我将向你展示如何使用这两种方法。

使用对象语法

要使用对象语法创建类绑定,必须使用JavaScript表达式。我们将使用的表达式可以在文中代码里可以看到。相关代码如下:

  

登录后复制

为了减少代码量,在这里使用了Vue中的 v-for 指令 。这个指令用于在循环中渲染项目。这个例子中的项目就是页面本身。除了使用 v-for 指令之外,还使用了 v-bind 指令。

v-bind 指令将元素的类属性绑定到Vue的实例。Vue的实例是这样定义的:

var app = new Vue({  el: '#myApp',  data: {    totalPages: 5,    currentPage: 3  }});

登录后复制

这个Vue实例上面的 data 对象包括了一个名为 currentPage 的属性。如果你重新访问上面定义的HTML模板,你将注意到该避属性正在被引用。实际上,与每个类绑定相关的JavaScript对象看起来是这样的:

{'page-item':true, 'active':(page === currentPage)}

登录后复制

该对象定义了两个属性: page-item 和 active 。值得注意的是,这些是步骤一中讨论的两个CSS类的名称。在步骤2中,这两个类引用已经成为JavaScript对象中的属性名。与这些属性名称关联的值是JavaScript表达式。如果表达式值为 true ,则将包括CSS类名。如果表达式值为 false ,则不包括CSS类。有了这些规则,我们来看看每个属性。

第一个属性 page-item 有一个 true 值。这个硬编码的值被使用,因为我们总是想要包括 page-item 类。第二个属性是 active ,它使用一个JavaScript表达式。当此表达式为 true 时,将应用 active 类。这使用我们可以根据 currentPage 的值有条件地应用 active 类。

body { width: 100vw; height: 100vh; display: flex; justify-content: center; align-items: center;}.pagination { justify-content: center;}

登录后复制

每次修改 currentPage 的值, active 就会应用其对应的列表项中。比如下图效果:

如何在Vue中有条件地使用CSS类

有条件地应用 active 类的另一种方法是绑定到一个数组。

使用数组语法

Vue允许通过绑定到一个数组给列表添加CSS类名。如果你想使用数组语法,步骤1中的HTML结构需要进行调整,修改后的代码如下:

  

登录后复制

和上一个示例的区别就是类绑定上使用数组。这种替代方法需要在 data 对象中添加两个额外的属性。这两个属笥是 pageItemClass 和 activeClass 。更新Vue初始化的代码:

var app = new Vue({  el: '#myApp',  data: {    totalPages: 5,    currentPage: 3,    pageItemClass: 'page-item',    activeClass: 'active'  }});

登录后复制

正如你看到了, data 对象变了,虽然 data 对象大小变大了,但是使用数组语法时,模板中的代码稍微干净一些。对象语法更紧凑一些。

对象语法和数组语法之间的选择归结为个人爱好。

这两种方法都可能使你的HTML模板更加复杂。然而,实际上还有更多的事情发生。在实现中,我们正在关注如何分离。我们正在创建一个由数据驱动的模板。这使用的视图更容易测试,并且在应用程序变大时更容易维护。

总结

本文根据 @Chad Campbell 的《 Conditionally Applying a CSS Class in Vue.js 》所译,整个译文带有我们自己的理解与思想,如果译得不好或有不对之处还请同行朋友指点。如需转载此译文,需注明英文出处: https://www.sitepoint.com/conditionally-applying-css-class-vue-js/ 。

相关推荐:

HTML5的classList属性操作CSS类的使用详解

HTML5的classList属性操作CSS类的使用详解

HTML5的classList属性操作CSS类的使用详解

以上就是如何在Vue中有条件地使用CSS类的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2788370.html

(0)
上一篇 2025年3月8日 18:25:33
下一篇 2025年3月8日 18:25:42

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 在Vue中有条件地使用CSS类实例详解

    很多时候web在运行时要更改元素的css类名。但是在改变类名时,有时最好是有条件地应用样式。例如你有一个翻页的效果。翻页效果通常有一个高亮的效果,用于向用户显示当前页,这对于用户而言是很有帮助的。该项目的样式是有条件设置的,基于当前正在查看…

    2025年3月8日
    200
  • 六种css三栏布局方法示例

    本文我们主要和大家分享六种css三栏布局方法示例, 谈到布局,首先就要想到定位,当别人问我,css的position定位有哪些取值,分别表示什么意思?呃…..抓头.gif,是时候回归本质,看定义了。 定位 position有六个…

    2025年3月8日
    200
  • jquery和css3实现熊猫tv导航代码分享

    本文主要给大家详细分享的是jquery+css3来写出熊猫tv导航的效果,以及代码分享,喜欢的朋友参考下。希望能帮助到大家。 实现原理 请看以下源代码              登录后复制                          …

    2025年3月8日
    200
  • CSS基础面试题小结

    本文主要和大家分享50道css基础面试题,希望能帮助到大家。 1 介绍一下标准的CSS的盒子模型?与低版本IE的盒子模型有什么不同的? 标准盒子模型:宽度=内容的宽度(content)+ border + padding + margin低…

    编程技术 2025年3月8日
    200
  • div和css布局的基本知识分享

    css和div都是页面布局离不开的语言代码,本文主要和大家分享div和css布局的基本知识,希望能帮助到大家。 1 p+css布局? 关键词: 盒子  位置 margin padding float position 学的是什么?从本质上来…

    编程技术 2025年3月8日
    200
  • jq和css自制轮播效果代码分享

    本文主要和大家分享jq和css自制轮播效果代码,希望能帮助到大家。 html部分: @@##@@@@##@@@@##@@这是我定义的第一张图这是我定义的第二张图这是我定义的第三张图 登录后复制  css部分: .banner1 {width…

    编程技术 2025年3月8日
    200
  • 关于CSS结构与层叠详解

    css 是 cascading style sheets 的缩写,这暗示层叠(cascade)的概念是很重要的。在最基本的层面上,它表明css规则的顺序很重要,但它比那更复杂。什么选择器在层叠中胜出取决于三个因素(这些都是按重量级顺序排列的…

    编程技术 2025年3月8日
    200
  • CSS选择器的优先级和权重分析

    本文主要和大家分享css 选择器的优先级和权重分析,希望能帮助大家更加掌握学习css选择器。 基本选择器 选择器 名 称 实 例 描 述 版 本 *通用选择器(Universal selectors)*匹配所有的元素2.1E标签选择器(Ty…

    编程技术 2025年3月8日
    200
  • css之margin属性详解

    作为前端狗的我们,每天都要和网页打交道。当 ui 将设计稿发给你时,css 的知识便显得尤为重要。而 css 这一标记性的语言,却时常让我很头疼:毫无逻辑性,并充满了各种坑爹的潜规则 ,以至于每次做项目时,大部分时间精力都浪费在了调整布局与…

    2025年3月8日
    200
  • table与css和div的之间的对比

    一.table简介   二.p+css简介 “p+CSS”其实是错误的叫法,而标准的叫法应是XHTML+CSS。因为p与Table都是XHTML或HTML语言中的一个标记,而CSS只是一种表现形式。 p +CSS有两重内在含义: 立即学习“…

    2025年3月8日
    200

发表回复

登录后才能评论