当前位置:首页 > 科技  > 软件

让CSS官方后悔的一些决定

来源: 责编: 时间:2023-10-13 14:38:03 368观看
导读CSS工作组在其官方WIKI[1]总结了这些年CSS在设计上犯的46条失误。这些错误大体可以概括为5类:属性key、value设计失误布局、对齐上的设计失误颜色相关的失误选择器设计失误本文会选一些「我觉得有意思」的失误来讲讲。

EKW28资讯网——每日最新资讯28at.com

CSS工作组在其官方WIKI[1]总结了这些年CSS在设计上犯的46条失误。这些错误大体可以概括为5类:EKW28资讯网——每日最新资讯28at.com

  • 属性key、value设计失误
  • 布局、对齐上的设计失误
  • 颜色相关的失误
  • 选择器设计失误

本文会选一些「我觉得有意思」的失误来讲讲。完整的失误列表见上述官方WIKI。EKW28资讯网——每日最新资讯28at.com

!important语法

!important语法用来增加样式的权重,毕竟,感叹号通常表达「强调」的意思。但在编程语言中,!通常是「取反」的意思,比如:EKW28资讯网——每日最新资讯28at.com

const isValid = true;!isValid // false

初次接触CSS的工程师很可能会觉得!important是「不important」的意思,这与该语法实际想表达的意思完全相反。EKW28资讯网——每日最新资讯28at.com

所以,工作组认为!important是个糟糕的语法。EKW28资讯网——每日最新资讯28at.com

z-index语法

z-index属性用于设置定位元素及其后代元素或flex元素的Z轴层叠顺序,z-index较大的元素会叠在较小元素的上面。EKW28资讯网——每日最新资讯28at.com

在编程语言中,index是「索引」的意思,并没有表达出「层叠」的意思。所以,工作组认为叫z-order或干脆叫depth(深度)会更好。EKW28资讯网——每日最新资讯28at.com

同时,他们也认为,这个属性应该对所有元素有效(而不是只对定位元素及其后代,以及flex元素有效)。EKW28资讯网——每日最新资讯28at.com

单个元素margin的塌陷

「margin坍塌」是CSS中的基础特性,假设有2个上下重叠的块级元素:EKW28资讯网——每日最新资讯28at.com

  • 上面的元素margin-bottom为20px
  • 下面元素margin-top为30px

按照直觉来看,他们之间的margin应该是50px(20px + 30px),但是由于「margin坍塌」,他们之间的margin为其中较大的值(30px)。EKW28资讯网——每日最新资讯28at.com

EKW28资讯网——每日最新资讯28at.com

上面是2个块级元素之间的「margin坍塌」。EKW28资讯网——每日最新资讯28at.com

对于单个块级元素,也存在「margin坍塌」 —— 如果一个元素内部没有内容,或者它的内容被清除(clear)了,那么这个元素的上下margin会发生塌陷。EKW28资讯网——每日最新资讯28at.com

这意味着,即使你为元素的顶部和底部都设置了margin,但实际上他们会合并成一个(值等于两者中的最大者,而不是它们的总和)。EKW28资讯网——每日最新资讯28at.com

这种塌陷行为可能会导致一些让人懵逼的布局问题。比如,你试图通过增加一个元素的margin-bottom来增加它下面的空间,但不起作用,可能就是因为增加的 margin塌陷掉了。EKW28资讯网——每日最新资讯28at.com

所以,CSS工作组认为这不是个好设计。EKW28资讯网——每日最新资讯28at.com

rgb与rgba

rgba与hsla都是设置颜色的属性,相比于rgb与hsl,他们还可以设置alpha值(透明度)。EKW28资讯网——每日最新资讯28at.com

所以,为啥不直接让rgb与hsl能够接收第四个参数(alpha值)呢?工作组很费解 自己当初咋想的。EKW28资讯网——每日最新资讯28at.com

border-radius

border-radius直译为「边界半径」,当初应该取名叫corner-radius(拐角半径)。EKW28资讯网——每日最新资讯28at.com

毕竟,这就是设置元素拐角处圆角的半径的啊~~EKW28资讯网——每日最新资讯28at.com

绝对定位的替换元素

所谓「替换元素」,是指「外观和尺寸由外部资源决定」的元素,比如:EKW28资讯网——每日最新资讯28at.com

  • img
  • object(嵌入的对象,如Flash动画)
  • video
  • iframe

工作组认为,当「替换元素」被绝对定位时,偏移属性不应该改变元素的位置,而应该改变尺寸。EKW28资讯网——每日最新资讯28at.com

比如,当对绝对定位的img设置left: 20px; right: 20px;,那么他应该被拉伸到「从左侧20px到右侧20px」的长度,而不是移动到距离左侧20px的位置。EKW28资讯网——每日最新资讯28at.com

这个规则对于响应式布局是非常有用的,因为它允许元素自动调整其大小以适应不同的视口宽度。EKW28资讯网——每日最新资讯28at.com

总结

上面只是挑了几个我觉得有意思的失误来聊。除此之外,还有很多是使用习惯上的设计失误,个人认为比较主观。比如:EKW28资讯网——每日最新资讯28at.com

  • 子孙选择器应该使用»符号,即:
// 当前的子孙选择器div p {  color: green;}// 期望的子孙选择器div » p {  color: green;}
  • 兄弟选择器应该用++符号,即:
// 当前的兄弟选择器div ~ p {  color: green;}// 期望的兄弟选择器div ++ p {  color: green;}

不知道上述改动,你能接受么?EKW28资讯网——每日最新资讯28at.com

参考资料

[1]官方WIKI:https://wiki.csswg.org/ideas/mistakes。EKW28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-13360-0.html让CSS官方后悔的一些决定

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 超越传统线程:探索Java Loom协程(纤程/虚拟线程)的无限潜力

下一篇: 去哪儿网架构演进之路:微服务的尽头原来是DDD……

标签:
  • 热门焦点
  • 一加Ace2 Pro真机揭晓 钛空灰配色质感拉满

    终于,在经过了几波预热之后,一加Ace2 Pro的外观真机图在网上出现了。还是博主数码闲聊站曝光的,这次的外观设计还是延续了一加11的方案,只是细节上有了调整,例如新加入了钛空灰
  • 官方承诺:K60至尊版将会首批升级MIUI 15

    全新的MIUI 15今天也有了消息,在官宣了K60至尊版将会搭载天玑9200+处理器和独显芯片X7的同时,Redmi给出了官方承诺,K60至尊重大更新首批升级,会首批推送MIUI 15。也就是说虽然
  • 俄罗斯:将审查iPhone等外国公司设备 保数据安全

    iPhone和特斯拉都属于在各自领域领头羊的品牌,推出的产品也也都是数一数二的,但对于一些国家而言,它们的产品可靠性和安全性还是在限制范围内。近日,俄罗斯联邦通信、信息技术
  • 红魔电竞平板评测:大屏幕硬实力

    前言:三年的疫情因为要上网课的原因激活了平板市场,如今网课的时代已经过去,大家的生活都恢复到了正轨,这也就意味着,真正考验平板电脑生存的环境来了。也就是面对着这种残酷的
  • 小米平板5 Pro 12.4简评:多专多能 兼顾影音娱乐的大屏利器

    疫情带来了网课,网课盘活了安卓平板,安卓平板市场虽然中途停滞了几年,但好的一点就是停滞的这几年行业又有了新的发展方向,例如超窄边框、高刷新率、多摄镜头组合等,这就让安卓
  • 6月安卓手机性能榜:vivo/iQOO霸占旗舰排行榜前三

    2023年上半年已经正式过去了,我们也迎来了安兔兔V10版本,在新的骁龙8Gen3和天玑9300发布之前,性能榜的榜单大体会以骁龙8Gen2和天玑9200+为主,至于那颗3.36GHz的骁龙8Gen2领先
  • 小红书1周涨粉49W+,我总结了小白可以用的N条涨粉笔记

    作者:黄河懂运营一条性教育视频,被54万人“珍藏”是什么体验?最近,情感博主@公主是用鲜花做的,火了!仅仅凭借一条视频,光小红书就有超过128万人,为她疯狂点赞!更疯狂的是,这
  • 重估百度丨“晚熟”的百度云,能等到春天吗?

    ©自象限原创作者|程心排版|王喻可2016年7月13日,百度云计算战略发布会在北京举行,宣告着百度智能云的正式启程。彼时的会场座无虚席,甚至排队排到了门外,在场的所有人几乎都
  • 利用职权私自解除被封帐号 Meta开除20多名员工

    11月18日消息,据外媒援引知情人士表示,过去一年时间内,Facebook母公司Meta解雇或处罚了20多名员工以及合同工,指控这些人通过内部系统以不当方式重置用户帐号,其
Top