你也许不知道,CSS 也有编程能力?

简介: 如今编程界有一种令人担忧的趋势——那些 “真正的” 程序员对 CSS 嗤之以鼻。 他们指出,这只是一种声明性语言,而不是一种功能齐全的编程语言。 啧啧啧,它甚至不是一种脚本语言。

image.png

原文作者:Jeremy Keith
译者:UC 国际研发 Jothy


如今编程界有一种令人担忧的趋势——那些 “真正的” 程序员对 CSS 嗤之以鼻。 他们指出,这只是一种声明性语言,而不是一种功能齐全的编程语言。 啧啧啧,它甚至不是一种脚本语言。

这可能是实话,但这并不意味着 CSS 不强大。 它的强大体现在与传统语言不同的地方。

以 CSS 选择器为例。 在最基本的层面上,它们像条件语句一样工作。 这是一个标准的 if 语句:

image.png

条件需要求值为 true 才能执行花括号中的代码。 听起来有点熟?

image.png

这是一个非常简单的映射,但如果条件语句更复杂怎么办?

image.png

那么,这就是后代选择器的作用:

image.png

实际上,通过使用子组合器,兄弟组合器和相邻的兄弟组合器,我们可以得到更具体的信息:

condition1 > condition2

condition1 ~ condition2

condition2 + condition2

AND 只是布尔逻辑的一部分。 还有 OR:

image.png

在 CSS 中,我们使用逗号分隔条件:

image.png

我们还使用 :not() 伪类来完成布尔可能性的集合。如果你添加了数量查询,通过 :nth-child 及其同类,CSS 看起来更像图灵完备了。我见过人们使用相邻的兄弟组合器和 :checked 伪类来构建状态机。

无论如何,我的观点是 CSS 选择器非常强大。然而,我们经常故意选择性地不使用这种力量。 OOCSS(面向对象的 CSS),BEM 和 Smacss 存在的理由正是故意限制选择器的功能,将其局限于类选择器。

从表面上看,这似乎是一个奇怪的选择。毕竟,我们不会故意将自己局限在编程语言的某个子集中,是吧?

答案是我们会,并且我们已经这样做了。这就是模板语言的用途。无论是 PHP 的 Smarty 还是 Twig,还是 JavaScript 的 Mustache,Nunjucks 或 Handlebars,它们都是实现了一部分小而美的功能。有些人为自己没有逻辑而自豪。如果你发现自己试图做一些模板化语言没有提供的东西,那么这是一个好的迹象,你不用试图在模板中这样做;它应该在控制器中完成。

因此,模板语言的存在是为了强制简化并确保复杂性发生在其他地方。这与 BEM 等的故事类似。如果你发现无法在 CSS 中选择某些内容,则表明你可能需要在 HTML 中添加另一个类名。复杂性仅限于 HTML 标记,以保持 CSS 更直接,模块化和可维护。

但是,我们也不要忘记这也是一个选择。并不是说 CSS 本身就无法执行复杂的条件。恰恰相反。正是因为 CSS 选择器(和级联)非常强大,我们才选择划清界限。

英文原文:

https://adactio.com/journal/14574

目录
相关文章
|
JavaScript 前端开发 开发者
编程笔记 html5&css&js 071 JavaScript Symbol 数据类型
编程笔记 html5&css&js 071 JavaScript Symbol 数据类型
258 0
|
JavaScript 前端开发
编程笔记 html5&css&js 079 JavaScript 循环语句
编程笔记 html5&css&js 079 JavaScript 循环语句
241 4
|
JavaScript 前端开发 开发者
编程笔记 html5&css&js 078 JavaScript 条件判断语句
条件判断语句是首先要接触的语句。通过条件判断来执行不同的代码块。
270 2
|
JavaScript 前端开发 Java
编程笔记 html5&css&js 073 JavaScript Object数据类型
编程笔记 html5&css&js 073 JavaScript Object数据类型
208 2
|
前端开发 JavaScript API
编程笔记 html5&css&js 062 JavaScript 如何使用
编程笔记 html5&css&js 062 JavaScript 如何使用
213 2
|
JavaScript 前端开发 编译器
编程笔记 html5&css&js 077 Javascript 关键字
编程笔记 html5&css&js 077 Javascript 关键字
176 1
|
JavaScript 前端开发
编程笔记 html5&css&js 076 Javascript 表达式
编程笔记 html5&css&js 076 Javascript 表达式
133 1
|
存储 JavaScript 前端开发
编程笔记 html5&css&js 075 Javascript 常量和变量
编程笔记 html5&css&js 075 Javascript 常量和变量
486 1
|
JavaScript 前端开发 程序员
编程笔记 html5&css&js 074 Javascript 运算符
编程笔记 html5&css&js 074 Javascript 运算符
181 1
|
JavaScript 前端开发
编程笔记 html5&css&js 068 JavaScript Boolean数据类型
编程笔记 html5&css&js 068 JavaScript Boolean数据类型
426 1

热门文章

最新文章

  • 1
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
    498
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
    387
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
    373
  • 4
    (CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
    247
  • 5
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
    490
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
    666
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
    1125
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
    261
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
    952
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
    447