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

栏目: CSS · 发布时间: 5年前

内容简介:原文作者:Jeremy Keith译者:UC 国际研发 Jothy

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

原文作者:Jeremy Keith

译者:UC 国际研发 Jothy

写在最前:欢迎你来到“UC国际技术”公众号,我们将为大家提供与客户端、服务端、算法、测试、数据、前端等相关的高质量技术文章,不限于原创与翻译。

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

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

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

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

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

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

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

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

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

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

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

  • condition1 > condition2

  • condition1 ~ condition2

  • condition2 + condition2

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

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

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

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

我们还使用 :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

预告: 第13届D2前端技术论坛将于2019年1月6日在杭州举办

好文推荐:

我想学Flutter,但是我不知道应该如何开始?

“UC国际技术”致力于与你共享高质量的技术文章

欢迎关注我们的公众号、将文章分享给你的好友

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


以上所述就是小编给大家介绍的《你也许不知道,CSS 也有编程能力?》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

CSS揭秘

CSS揭秘

[希] Lea Verou / CSS魔法 / 人民邮电出版社 / 2016-4 / 99.00元

本书是一本注重实践的教程,作者为我们揭示了 47 个鲜为人知的 CSS 技巧,主要内容包括背景与边框、形状、 视觉效果、字体排印、用户体验、结构与布局、过渡与动画等。本书将带领读者循序渐进地探寻更优雅的解决方案,攻克每天都会遇到的各种网页样式难题。 本书的读者对象为前端工程师、网页开发人员。一起来看看 《CSS揭秘》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试