返回顶部
首页 > 资讯 > 前端开发 > html >如何理解CSS中的属性模块
  • 224
分享到

如何理解CSS中的属性模块

2024-04-02 19:04:59 224人浏览 泡泡鱼
摘要

本篇内容主要讲解“如何理解CSS中的属性模块”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解CSS中的属性模块”吧!更多 vs 更少 - 简单比较神奇的是

本篇内容主要讲解“如何理解CSS中的属性模块”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解CSS中的属性模块”吧!

更多 vs 更少 - 简单比较

神奇的是,虽然在标签里面放那么多类让我非常不爽,可是人们爱哈利,因为他太特么能说了。提倡的某些东西,比如说 OOCSS 和单一责任原则,从我自己创建的一系列日益复杂的网站来看,我可以说这确实值得对样式行为进行解耦,不过直到最近我才找到一种让我觉得满意的方式来实现它。

我原先有做过一个 BEM 的版本,它强调了独立高于重用 ‐ 每个新的块默认是没有样式继承的,允许组件独立开发并且可以避免打乱页面其它样式的风险。不过代价就是碎片化(fragmentation) ‐ 忽然你会发现你有了 10 种不同的样式链接,12 种不同的蓝色,18 种差别细小的按钮样式等。妮可?沙利文,OOCSS 的作者,去年在墨尔本做了一个超赞的演示,讲到了这个问题是有多普遍,以及怎么解决它。


对我来说,我觉得可以接受的解决方案是,深入 CSS 的预处理机能,从而取得 BEM 的独立性以及 OOCSS 的一致性。比如说,下面这样的:
 

CSS Code复制内容到剪贴板

  1. <a class='btn large rounded'>   

  2.     

  3. .btn {  }   

  4. .large {  }   

  5. .rounded {  }  

应该改成这样:
 

CSS Code复制内容到剪贴板

  1. <a class='btn btn--large btn--rounded'>   

  2.     

  3. .btn {  }   

  4. .btn--large {  @extend %large-type;}   

  5. .btn--rounded {  @extend %rounded-borders;}  

我成功终结了充满了占位符的文件,比如满眼都是那些_typography.scss 和 _brand.scss,这不但让我有能力控制碎片化,同时还能默认保持了样式的对每个新组件的独立性。所有的东西都挺好的,起码有那么一段时间是这样。

修饰符: M 是怎样破坏 BEM 的

只要你做关于 CSS 类的命名 & 维护方面的任何研究,你一定会要看到尼古拉斯.加拉格尔的杰作"关于 html 的语义和前端架构"。其中一部分特别吸引我,他称之为修饰符的 '单类模式' vs '多类模式'。简单的说,你的 HTML 会有两个版本,看起来像这样:
 
这通过两个备选的 CSS 模式实现:

 

CSS Code复制内容到剪贴板

  1.   

  2. .btn, .btn--large {  }   

  3. .btn--large {  }   

  4.     

  5.   

  6. .btn {  }   

  7. .btn--large {  }  

这两个模式的差别在于 btn--large 是否只要它自己就足够了,还是说它需要依赖类 btn 。单类模式说”可以”,它看起来更简单而且可以避免有人忘记把 btn 包含进来的情况。而且它也不啰嗦,配合 SASS 的 @extend 方法,它对 CSS 来说不像一个负担,只不过它有一个致命伤。

上下文重写

我们假设你的所有按钮都有背景色,除了你顶部导航栏那些没有。在多类模式下,所有的按钮,大的小的,圆的方的,等等之类,都会包含类 btn,所以你可以这样写:
 

CSS Code复制内容到剪贴板

  1. header > nav > .btn { background: none; }  

而在单类模式中,我们不知道哪种按钮会被重写,所以你只好这样:

 

CSS Code复制内容到剪贴板

  1. header > nav {  .btn, .btn--large, .btn--rounded { background: none; }}  

很显然,这不理想 - 追加一个按钮变体也就意味着要检查所有地方的按钮样式重写以及添加一个新类。用属性前缀选择器 ^=,可以检查你的属性是否以特殊字符串开头,比如:
 

CSS Code复制内容到剪贴板

  1. <a class='btn--large'>   

  2.     

  3. [class^='btn'] {  }   

  4. .btn--large {  }   

  5. header > nav > [class^='btn'] {  }  

这实现了单类模式下的简单的上下文重写,不过它还是太弱了,不是一个可以托付的选择。最致命的是,如果另一个类在 btn--large 出现,而且前缀选择器还没匹配到它,那么之后的所有的都完蛋了。而且,它还没有显式的方法来指定多个变种,比如说 btn--large--rounded。

我很欣赏这种创造性的方式,不过还是死路一条。好吧,到这里我特么操蛋了,吐,直到忽然某天我灵光一闪。
 
为什么要用类?

不要在意我那么直接这种小问题,不过给我个理由先,为什么类是我们放样式信息的唯一位置?HTML生存守则如是说:

    3.2.5.7 类属性

    属性,如果要指定,就必须有一个用来标记该元素属于不同类的值,该值用一组空格分隔符来表示。

    而开发者在类属性中怎样使用该标记是没有任何限制的,但是鼓励开发者使用描述该内容的属性性质的表达,而不是描述该内容所期待呈现何种结果的表达。

所以对吧,我们用类来描述"内容的属性性质"是很有道理的,但是好像我们对类需求过度了吧。一个属性就包括了所有的东西,从巨大的 BEM-风格 命名,比如说 primary-nav__sub-nav--current 到像 u-textTruncate 或者 left 或者 clearfix,到 javascript 用的比如说 js-whatevs,然后我们花了巨多时间来解决命名冲突的问题,然后还希望他们有很好的可读性。

通过约定 & 习惯这是可控的,而且还有像文章前面说到的哈利的那种技术也挺有用的,不过,有一个事实是,我们所有的操作都是基于一个全局命名空间(global namespace)的,不管有多少规约都无法改变的事实。这让我们下面出场的 AM 就有那么一点不同了。

在我们正式开始讨论它之前,我们来复习一下 CSS 一个鲜为人知的特点。

欢迎 ~= 登场,神奇的选择器

从 IE7 开始,浏览器开始支持一种超厉害的 CSS 规则,叫做空格分隔属性选择器(space-separated attribute selector)。它可以匹配任何属性值,通过空格分隔,就像它们是类一样。下面两行的 CSS 是等价的:
 

CSS Code复制内容到剪贴板

  1. .dat-class {  };   

  2. [class~='dat-class'] {  };  

和 <div class='a b c'> 一样,它不在意 a,b 和 c 的顺序,也不在意是不是还有其它, ~= 选择器也不在意。不过 ~= 不限于类(class)属性,这就是这种全新技术的关键。

属性模块(Attribute Modules)

属性模块,或者叫 AM,它的核心是如何为你的样式定义命名空间。让我们从一个简单的例子开始,一个网格,首先用类的方式描述:
 

CSS Code复制内容到剪贴板

  1. <div class="row">   

  2.     <div class="column-12">Full</div>   

  3. </div>   

  4. <div class="row">   

  5.     <div class="column-4">Thirds</div>   

  6.     <div class="column-4">Thirds</div>   

  7.     <div class="column-4">Thirds</div>   

  8. </div>   

  9.   

  10.     

  11. .row {  }   

  12. .column-1 {  }   

  13. .column-2 {  }   

  14. .column-3 {  }   

  15. .column-4 {  }   

  16. .column-5 {  }   

  17.   

  18. .column-12 {  }  

好了,然后我们用属性模块方式来做。我们有两个模块,行(rows) 和 列(columns) 。行,现在还没有变化,列有 12 列。
 

CSS Code复制内容到剪贴板

  1. <div am-Row>   

  2.     <div am-Column="12">Full</div>   

  3. </div>   

  4. <div am-Row>   

  5.     <div am-Column="4">Thirds</div>   

  6.     <div am-Column="4">Thirds</div>   

  7.     <div am-Column="4">Thirds</div>   

  8. </div>   

  9.     

  10. [am-Row] {  }   

  11. [am-Column~="1"] {  }   

  12. [am-Column~="2"] {  }   

  13. [am-Column~="3"] {  }   

  14. [am-Column~="4"] {  }   

  15. [am-Column~="5"] {  }   

  16.   

  17. [am-Column~="12"] {  }  

首先你肯定会注意到了它们的 am前缀(am-prefix)。这是 AM 核心的一部分,它确保了属性模块不会和现有属性冲突。你也可以用任意你喜欢的 ‐ 我试过用 ui- ,css- 还有其它一些,不过这个例子里面我们约定用 am-。如果 HTML 校验对你的或者你项目来说很重要,那你就选个 data-,意思也是一样的。

第二个你会注意到应该就是那些值了,什么 "1","4" 还是 "12" 的,看起来非常糟糕 的类名 ‐ 它们太普通所以有太高的冲突几率了。不过因为我们已经定义了我们的命名空间,它只在我们规定的地方起作用,所以我们可以随便用那些我么你觉得最简明最有意义的字符。

灵活的属性

到目前为止,差别相当细微。不过因为每个模块都有它自己的命名空间,让我们拿我们的值做个不一样的尝试:
 

CSS Code复制内容到剪贴板

  1. <div am-Row>   

  2.     <div am-Column>Full</div>   

  3. </div>   

  4. <div am-Row>   

  5.     <div am-Column="1/3">Thirds</div>   

  6.     <div am-Column="1/3">Thirds</div>   

  7.     <div am-Column="1/3">Thirds</div>   

  8. </div>   

  9.     

  10. [am-Row] {  }   

  11. [am-Column] {  }   

  12. [am-Column~="1/12"] {  }   

  13. [am-Column~="1/6"] {  }   

  14. [am-Column~="1/4"] {  }   

  15. [am-Column~="1/3"] {  }   

  16. [am-Column~="5/12"] {  }   

  17.   

现在我们可以用命名来让我们的作用域看起来更有意义了 ‐ 一个宽是 1/3 标记让我们立刻能想起我们需要有 4 列,因为我们用的是一个 12-列 的网格。我们还为所有的列定义了一个默认样式 ‐ 也就是属性 column ,没有值的列将会被视为全宽的列。此外,我们还可以把一些重复的逻辑 (事实上列是左对齐的)移到了这个属性规则里面。

格式化所有的属性和值

这是这种方法的核心优点之一。存在一个基础属性,比如 am-Button,可以并且应该定义样式。这个属性的每个扩展值则应该继承或者重写这个基础样式。

在上面的网格例子中,我们正是这样做的:标签 am-Column="1/3" 匹配到了两个属性[am-Column] 和 [am-Column~="1/3"],因此结果就是基础样式 + 改变。它给我们提供了一种方式来实现 所有的列都是columns 而不需要用重复的类或者用 SASS 的 @extend方法。

BEM 的零类(zero-class)模式

回到我们的 BEM 中的单类模式 vs 多类模式上来,AM 给了我们一个零类模式选项。比如说上面的按钮的例子,标记看起来是这样的:
 

CSS Code复制内容到剪贴板

  1. <a am-Button>NORMal button</a>   

  2. <a am-Button='large'>Large button</a>   

  3. <a am-Button='rounded'>Rounded button</a>   

  4. <a am-Button='large rounded'>Large rounded button</a>   

  5.     

  6. [am-Button] {  }   

  7. [am-Button~="large"] {  }   

  8. [am-Button~="rounded"] {  }  

通过创建一个新的属性模块 am-Button,我们可以分离出适用于所有按钮的样式,比如那些大按钮,还有那些圆角按钮。我们不仅可以自由的组合这些变化(比如 am-Button='large rounded'),我们还可以针对这些属性本身做任何的上下文覆盖:
 
现在不管你选什么样式的按钮,或者你选多少种样式的按钮都不是问题了,关键是,所有的按钮都会适用选择器[am-Button],这样我们就知道我们的覆盖是有效的了。

到此,相信大家对“如何理解CSS中的属性模块”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: 如何理解CSS中的属性模块

本文链接: https://lsjlt.com/news/81964.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何理解CSS中的属性模块
    本篇内容主要讲解“如何理解CSS中的属性模块”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解CSS中的属性模块”吧!更多 vs 更少 - 简单比较神奇的是...
    99+
    2024-04-02
  • 如何理解CSS属性中的vertical-align
    这篇文章主要讲解了“如何理解CSS属性中的vertical-align”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何理解CSS属性中的vertical-...
    99+
    2024-04-02
  • 如何理解CSS属性中的z-index
    这篇文章主要讲解了“如何理解CSS属性中的z-index”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何理解CSS属性中的z-index”吧!如果你不是一...
    99+
    2024-04-02
  • 如何理解CSS属性中高的min-width
    这篇文章主要讲解了“如何理解CSS属性中高的min-width”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何理解CSS属性中高的min-width”吧!...
    99+
    2024-04-02
  • 如何理解css中position的五个属性
    如何理解css中position的五个属性,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。在实际开发页面布局时,运用positi...
    99+
    2024-04-02
  • 如何理解CSS中的Position和Float属性
    本篇文章给大家分享的是有关如何理解CSS中的Position和Float属性,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。本文结构点:1.HT...
    99+
    2024-04-02
  • 如何理解CSS属性中的overflow及相关属性text-overflow
    这篇文章主要介绍“如何理解CSS属性中的overflow及相关属性text-overflow”,在日常操作中,相信很多人在如何理解CSS属性中的overflow及相关属性text-overflow问题上存在...
    99+
    2024-04-02
  • 如何理解CSS编写中的属性优先级
    今天就跟大家聊聊有关如何理解CSS编写中的属性优先级,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。当你将一个样式添加到元素上却发现不起作用时,那就是...
    99+
    2024-04-02
  • pycharm报错模块没有属性如何解决
    当 PyCharm 报告模块没有属性时,可能是由以下几个原因引起的:1. 模块导入错误:请确保正确导入模块,并且模块名称拼写正确。如...
    99+
    2023-09-27
    pycharm
  • 如何理解CSS position属性中absolute和relative的应用
    这期内容当中小编将会给大家带来有关如何理解CSS position属性中absolute和relative的应用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望...
    99+
    2024-04-02
  • 深入理解CSS中position属性的常见属性值
    绝对定位的常用属性值解析:学习CSS中的position属性,需要具体代码示例CSS中的position属性可以用于控制元素在页面上的定位方式。其中,绝对定位是position属性值之一,主要用于将元素脱离文档流,并相对于最近的祖先元素进行...
    99+
    2023-12-28
    绝对定位 CSS学习 position属性
  • 如何理解css字体样式中Font Style属性
    如何理解css字体样式中Font Style属性,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。css文本样式 序号中文说明标记语法1字体样式{...
    99+
    2024-04-02
  • 如理解CSS属性中的word-break与word-wrap
    这篇文章主要介绍“如理解CSS属性中的word-break与word-wrap”,在日常操作中,相信很多人在如理解CSS属性中的word-break与word-wrap问题上存在疑惑,小编查阅了各式资料,整...
    99+
    2024-04-02
  • 如何理解JavaScript中的ES模块
    如何理解JavaScript中的ES模块,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。模块在每个编程语言中都能找到。它是一种能在一个代码块...
    99+
    2024-04-02
  • 如何理解Vue中的ref属性
    这期内容当中小编将会给大家带来有关如何理解Vue中的ref属性,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。上述就是小编为大家分享的如何理解Vue中的ref属性了,如果刚好有类似的疑惑,不妨参照上述分析进...
    99+
    2023-06-25
  • css中content属性如何用
    今天小编给大家分享一下css中content属性如何用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了...
    99+
    2024-04-02
  • css中如何定位属性
    本篇内容介绍了“css中如何定位属性”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • css中如何实现模块化
    css中如何实现模块化?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。oocss面对对象的规则,主要的原则是两种:分离结构和外观,分离容器和内容。名词解释分离结构和外观:增加...
    99+
    2023-06-08
  • CSS中margin-top属性失效如何解决
    本篇文章给大家分享的是有关CSS中margin-top属性失效如何解决,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。关于margin-top属...
    99+
    2024-04-02
  • CSS中clip属性如何使用
    这篇文章将为大家详细讲解有关 CSS中clip属性如何使用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。CSS clip 属性定义和用法clip 属性剪裁绝...
    99+
    2024-04-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作