CSS并不是真正的编程语言

更新日期: 2019-03-21 阅读: 4.4k 标签: 编程

每隔几个月就会出现一篇文章表明:css并不是真正的编程语言。以编程语言的标准来说,CSS过于困难。使用这门语言会很有创造性:

人们对CSS有一些强烈的情愫。— Dave Rupert (@davatron5000) [September 18, 2017]

事实确实如此,CSS不同于传统的编程,且具有缺陷,同任何标准化编程语言相比,使用起来都更为困难。这是由于CSS被设计为一种描绘界面的方式,而不是以编程形式实现该界面,例如canvas的api。CSS的设计初衷就不同于传统编程语言。

CSS为用户上网时遇到的一些复杂且未知的东西创建界面,这个设计初衷是很棒的。作为一名CSS开发者,你相信用户代理(大部分情况下指的是浏览器)会表现正确的行为。你无法控制CSS发生的时机,但同时你也无需担心性能、渲染时间和响应的具体细节,因为这些细节是由浏览器开发者和浏览器所处操作系统决定的。不过很棒的一点是,CSS允许你在其应用的地方修改这些重要的细节。如果你使用JavaScript来创建界面或动画,你不仅需要做更多深入细致的控制,还要确保一切都能正常工作,否则可能会阻塞页面的正常显示。使用CSS就意味着放弃控制,而去花更多的时间创建友好的响应式交互界面。用户可能会搞乱你的界面设置,但CSS可以为你规避这种情况。

使用CSS开发不同于传统模式,并不需要循环、条件和变量。但CSS正朝着这个方向发展,Sass作为CSS的扩展语言,引入了变量,为CSS未来的发展奠定了基础。但CSS最需要的不是语法,而是你要清楚使用CSS所描绘的界面是什么。其次,如何确保你使用CSS编写的界面是足够灵活的,以至于用户无法触发页面的错误也不会无法访问页面。当你理解了html并使用CSS来控制它的样式时,你能够减少很大的代码量。

你的用户们的忠诚度依赖于所在的技术平台,如果你不打算创建友好的交互来提升用户体验,增加用户的留存度,CSS可能并不适合你。CSS被设计为一种“宽容“的语言,当你的一些代码无法起作用时,CSS也不会报错。因此,渐进增强是很棒的设计。你无需担心因添加了一行不支持的代码而出错,解析器会跳过它不支持的属性。当遇到错误时,JS解析器会中断解析并且抛出错误信息,而CSS解析器会忽略这些错误并继续解析。这对于想要知道错误信息的开发者来说会很奇怪,但是却让你从需要使用if来包含各种情况、兼容所有可能使用的浏览器这一状况下解脱出来。如何对按钮使用渐变效果?首先,定义一个背景色,然后在下一行设置背景为渐变。如果浏览器不支持渐变效果,它依旧会渲染出一个正常的按钮,只不过背景不是渐变而已。在这个过程中,你根本无须担心浏览器是否支持渐变。

由于对CSS的设计目的不了解而产生了错误认知,才导致出现了很多“CSS不是真正的编程”的观点。如果你想要完全控制一切,比如界面、甚至精细到像素的话,请不要使用CSS。相反,如果你想要构建一个包罗广泛、多种多样的页面,CSS是个很好的工具。编写CSS需要站在用户的角度考虑,设计拥有良好交互的页面,提升用户体验,但这并不是说你把一个Photoshop生成的图片放到页面就好了。使用CSS构建页面需要不同于后端语言的技术栈,其次,作为维护者、编写者的心态也要发生转变。

不管怎么说,轻视CSS开发者、将他们视为非纯正开发者,这种傲慢的想法略显荒谬。尤其是在你甚至都没花时间了解CSS的设计目的是什么,以及它目前惊人的发展速度。

从另一方面来说,CSS本不是也不应该是任何问题的解决方式。例如,你可以创建带有阴影的像素,但同时也会对浏览器渲染引擎带来渲染压力。

对我来说,CSS就是Web的一部分;对有些人来说,CSS的语法显得很奇怪,以至于让他们觉得是另一种编程语言。不过这些年来,随着CSS的发展,它的价值毋庸置疑。在未来很长一段时间,CSS应该也不会消失。因此,如果你不喜欢使用CSS,那就和会使用的人合作开发网页。

与其讨论“CSS是否有缺陷,需要被替代”的问题,不如以一种积极健康且不同于以往的角度讨论CSS:

  • CSS可以做什么,它有什么不足
  • 有哪些过去需要其他技术才能实现的,而现在CSS就可以做到的事情,以及如何应用
  • 如何编写可维护的CSS
  • 你能够做什么,来使CSS开发者的开发过程更简单、容易?
  • 我们使用哪些CSS hack,为什么不应该再用它们
  • 我们可以做什么来让CSS这门语言变得更好、更丰富?


本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://fly63.com/article/detial/2947

相关推荐

在线运行编程网站

学编程的程序员小伙伴越来越多了,在学习的过程中会发现很多知识点如果不在工作中运用或者手写带验证的话,很容易忘记。任何技能的掌握都是需要不断练习的。在此整理一些在线运行编程的网站。

前端的编程软件哪些比较好用?

推荐8款最好用的前端开发工具供美工或者前端开发人员使用,当然若你是NB的全栈工程师也可以下载使用。Web前端开发最常见的编程软件有以下几种: 在前端开发中,有一个非常好用的工具,Visual Studio Code,简称VS code

程序员的笔记,编程写软件学到的 7 件事

如果你真的做出了一些东西,在面对那些令人眼花缭乱的理论知识,或是和你相似甚至比你做的更糟糕的人时大可不必谦虚。在一天结束之时,正是那些在战壕中的开发者——构建、测试和开发了代码的人,真正做了事情。

十大编程语言榜单

如果你是软件开发领域的新手,那么你会想到的第一个问题是“如何开始?”编程语言有数百种可供选择,但是你怎么发现哪个最适合你,你的兴趣和职业目标又在哪里呢?选择最佳编程语言以学习的最简单方法之一,是通过市场反响、技术趋势的发展…

Blockly - 来自Google的可视化编程工具

Google Blockly 是一款基于Web的、开源的、可视化程序编辑器。你可以通过拖拽块的形式快速构建程序,而这些所拖拽的每个块就是组成程序的基本单元。可视化编程完成

感觉自己不适合做程序员,什么样的人不适合做程序员?

学习是一件艰苦的事情。很多人想要成为程序员,在学习编程的过程中,面对各种 bug 和源源不断的问题,有时会对自己是否适合编程这一问题产生困扰。在教学的过程中,他总结出了不适合做程序员的十个特征

自学编程的网站有那些?

如今,很大一部分人在学习编程的道路上都选择自学,但都苦于找不到适合自己的学习资源,今天为大家介绍11个免费的自学编程的网站,为大家提供一些帮助。很多人自学编程,都会通过w3school,你可以通过它学习所有的网站建设基础教程

无码编程:无代码软件开发大行其道

代码是大多数软件程序和应用程序的骨干。每行代码充当一条指令:采用一种逐步性的逻辑机制,以便计算机、服务器和其他机器执行操作。想创建那些指令,就要知道如何编写代码,这项宝贵的技能有时很吃香。

自学编程的六个技巧总结

这些事情可以帮助新手在他们漫长的旅程中学习编程。我知道我还有更多东西需要学习,并将继续学习如何永远地学习。最重要的事情说三遍,请继续,不要放弃,不要放弃,不要放弃。

编程到底难在哪里?

以买苹果为例说明程序员如何解决问题。程序员需要对问题进行透彻的分析,理清其涉及的所有细节,预测可能发生的所有意外与非意外的情况,列出解决方案的所有步骤,以及对解决方案进行尽量全面的测试。而这些正是我认为编程难的地方。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!