css – 为什么专业网站有奇怪的#id和.class名称?

我注意到facebook和gmail有很多#id和.class名字.

他们有意混淆它们吗?还是他们的IDE呢?
有这样不可读的开发名称似乎是合乎逻辑的

例如 – 这是gmail的刷新按钮.将id / class设置为“刷新”是合理的

<div class="G-Ni J-J5-Ji" style="">
<div class="T-I J-J5-Ji nu T-I-ax7 L3" act="20" role="button" tabindex="0" style="-webkit-user-select: none;" data-tooltip="Refresh" aria-label="Refresh">
<div class="asa">
<span class="J-J5-Ji ask">&nbsp;</span><div class="asf T-I-J3 J-J5-Ji"></div></div></div></div>

和Facebook的帖子按钮进行状态更新

<button class="_42ft _42fu _11b selected _42g-" type="submit">Post</button>

性能上 – 确实具有较短的名称真正影响加载时间?它似乎是(对于一个页面,如Facebook或Gmail)几个100kb更多,这与现在的宽带线在所需的时间可以忽略不计

在异常 – twitter和pinterest有可读名称

解决方法

更新:CSS模块

这种做法现在被称为“CSS模块”,随着Webpack的普及而越来越广泛的应用.这个概念是将(哈希)CSS选择器转换成唯一的类名,以确保模块之间没有样式的冲突.

用于Webpack的css-loader module具有启用此功能的模块选项.它通常与React一起使用,您可以通过导入CSS文件(例如,CSS)提供的JS对象在标记中分配类名.

import styles from './style.css

如果该CSS文件具有选择器,例如.sidebar,它通过标记应用

className={styles.sidebar} // JSX

Webpack将散列类名称和高级选择器以确保唯一性.

原始答案↓

这将是缩小和压缩的产物.毫无疑问,用人类可读取的id和类名可以写出来,但是像Zeta已经评论过的那样,这些代码用缩写代替来保存字节.这样的事情对于普通网站来说并不重要,但是当您每分钟浏览几十页浏览量时,这一切都是重要的.

看看developmentproduction版本的jQuery之间的区别.这是缩小和压缩结果的一个例子.

相关文章

Css3如何实现鼠标移上变长特效?(图文+视频)
css3怎么实现鼠标悬停图片时缓慢变大效果?(图文+视频)
jquery如何实现点击网页回到顶部效果?(图文+视频)
css3边框阴影效果怎么做?(图文+视频)
css怎么实现圆角边框和圆形效果?(图文+视频教程)
Css3如何实现旋转移动动画特效