XingYun blog
  • JS基础

    • 图解js原型链
    • JS Event Loop
    • 对象的底层数据结构
    • 让你的JavaScript代码简单又高效
    • 函数参数按值传递
    • 判断数据类型
    • 浮点数精度问题和解决办法
    • 常用方法snippet
    • 实现Promise
    • 防抖和节流
    • 巧用sort排序
  • CSS && HTML

    • CSS也需要性能优化
    • class命名规范
    • em、px、rem、vh、vw 区别
    • CSS揭秘阅读笔记
  • 浏览器

    • 浏览器是如何渲染页面的
    • 重排和重绘
    • BOM浏览器对象模型
    • DOM事件
    • 浏览器存储
  • 数据结构

    • JS实现链表
    • JS实现栈与栈应用
    • JS实现常见排序
    • 哈夫曼编码
    • MD5算法
  • vue原理浅析

    • Vue虚拟dom与Diff算法
    • 前端打包文件的缓存机制
    • vue数组为什么不是响应式
    • v-for为什么不能用index做key
  • 前端工程化

    • 浏览器是如何渲染页面的
    • 前端打包需要gzip压缩吗
    • 前端打包文件的缓存机制
    • webpack loader和plugin
  • 轮子&&组件库

    • 实现水波浪进度球
  • 文字转语音mp3文件
  • 文件上传前后端实现
  • moment.js给定时间获取自然月、周的时间轴
  • 实现文件上传功能
  • 批量下载照片
  • leaflet改变坐标原点
  • 网络

    • 有了MAC地址 为什么还需要IP地址
    • 为什么IP地址老是变
    • 我们为什么需要IPV6
    • TCP与UDP
  • 计算机组成原理

    • ASCII、Unicode、UTF-8和UTF-16
  • VSCode

    • VSCode图片预览插件 Image preview
    • rsync:linux间的高效传输工具

XingYun

冲!
  • JS基础

    • 图解js原型链
    • JS Event Loop
    • 对象的底层数据结构
    • 让你的JavaScript代码简单又高效
    • 函数参数按值传递
    • 判断数据类型
    • 浮点数精度问题和解决办法
    • 常用方法snippet
    • 实现Promise
    • 防抖和节流
    • 巧用sort排序
  • CSS && HTML

    • CSS也需要性能优化
    • class命名规范
    • em、px、rem、vh、vw 区别
    • CSS揭秘阅读笔记
  • 浏览器

    • 浏览器是如何渲染页面的
    • 重排和重绘
    • BOM浏览器对象模型
    • DOM事件
    • 浏览器存储
  • 数据结构

    • JS实现链表
    • JS实现栈与栈应用
    • JS实现常见排序
    • 哈夫曼编码
    • MD5算法
  • vue原理浅析

    • Vue虚拟dom与Diff算法
    • 前端打包文件的缓存机制
    • vue数组为什么不是响应式
    • v-for为什么不能用index做key
  • 前端工程化

    • 浏览器是如何渲染页面的
    • 前端打包需要gzip压缩吗
    • 前端打包文件的缓存机制
    • webpack loader和plugin
  • 轮子&&组件库

    • 实现水波浪进度球
  • 文字转语音mp3文件
  • 文件上传前后端实现
  • moment.js给定时间获取自然月、周的时间轴
  • 实现文件上传功能
  • 批量下载照片
  • leaflet改变坐标原点
  • 网络

    • 有了MAC地址 为什么还需要IP地址
    • 为什么IP地址老是变
    • 我们为什么需要IPV6
    • TCP与UDP
  • 计算机组成原理

    • ASCII、Unicode、UTF-8和UTF-16
  • VSCode

    • VSCode图片预览插件 Image preview
    • rsync:linux间的高效传输工具
  • leaflet改变坐标原点
  • 补间动画gsap与tween
  • 文字转语音mp3文件
  • JavaScript引入
  • JavaScript高级程序设计阅读笔记
  • Javascript函数参数按值传递传递
  • JS防抖和节流
  • 手写JS常用方法
  • 手写Promise
  • JS Event Loop
  • 重排和重绘
  • em、px、rem、vh、vw 区别
  • css也需要性能优化
  • 图解 js 原型链
  • js函数参数按值传递
  • BOM浏览器对象模型
  • DOM
  • 事件
  • js对象数组sort按需排序
  • 文件上传功能技术选型和前后端实现
  • 前端图片处理
  • 让你的JavaScript代码简单又高效
  • BEM:class命名规范
  • 前端规范-CSS属性那么多(杂),怎么排序
    • TypeScript Tips
    • jsx
    • canvas基础
    • 前端日志
    • 浏览器存储
    • CSS世界阅读笔记
    • CSS揭秘阅读笔记
    • js变量命名常用规范词
    • 你不知道的JavaScript阅读笔记
    • js对象的底层数据结构
    • js判断数据类型
    • JS浮点数精度问题和解决办法
    • js作用域
    • js堆栈溢出和内存泄漏
    • 浏览器是如何渲染页面的
    • 疑难杂症和踩坑问题合集
    • 免费在线API收集
    • 原生JS实现Ajax请求
    • cookie、session、localStorage、sessionStorage的区别
    • Sass与Less
    • arrayBuffer、blob、file对象
    • TypeScript基础
    • 前端
    XingYun
    2022-03-09
    目录
    一、怎么排?
    二、这么多属性顺序,硬背下来吗?

    前端规范-CSS属性那么多(杂),怎么排序

    前端就是“面向规范编程”, 可是 CSS 属性那么多(杂), 怎么排序,好像没有一个标准的规范。

    作为 3 年老前端, 刚开始写代码时我都是按照布局和样式,把属性一条一条往上加,直到达到我想要的效果就完了。

    很明显,这样做不够“优雅”。

    # 一、怎么排?

    后来在各种项目里摸爬滚打了三年,我个人认为按 ‘属性类型’ 排序最实用。

    div {
      /* 定位相关属性 */
      position: absolute;
      z-index: 10;
      top: 0;
      right: 0;
      bottom:0;
      left:0;
    
      /* 盒子模型相关属性 */
      display: inline-block;
      justify-content: center;
      overflow: hidden;
      box-sizing: border-box;
      width: 100px;
      height: 100px;
      padding: 10px;
      border: 10px solid #333;
      margin: 10px;
    
      /* 背景色 字体颜色 */
      background: #000;
      color: #fff
    
      /* 字体相关属性 */
      font-family: sans-serif;
      font-size: 18px;
      line-height: 1.5;
      text-align: right;
    
      /* 其它不常用属性 */
      cursor: pointer;
    }
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33

    这么排序有以下几个好处

    1. ‘重要的’ 影响页面结构的属性放前面, 可以引起足够重视。 试想一下你维护别人的 CSS 代码时, 看到某个类下面有 20 行属性,是不是看两行就跳过了。

    2. 符合搭建页面的编码流程:我们写页面时,一般是 固定位置 -> 盒子模型相关控制排列规则 -> 背景色、字体颜色、字体相关属性 -> 加上一些特殊的不常用属性。如果 CSS 属性也按照开发顺序排列就会感觉很自然,很流畅。

    3. 维护方便: 需要修改某个属性时,方便定位。

    # 二、这么多属性顺序,硬背下来吗?

    要在团队里推行这套规则光靠成员自觉把这些属性顺序背下来是不太可能的。

    幸运的是 vscode 有一个插件可以完美解决需求。

    CSScomb (opens new window)

    插件市场搜索安装后在 setting.json 里加入下面配置

      "csscomb.preset": "zen" // 按照模板zen格式化
    
    1

    macOS 按 Cmd+Shift+P ( Windows Ctrl+Shift+P ) 执行 CSScomb

    这样我的 Vue 文件里的 CSS 代码就自动排好序了

    这个插件最赞的是,它可以自定义排序规则,官方提供了三种自定义规则 (opens new window)

    如果你的团队想自定义某些规则,可以下载这个 JSON 模板,然后按需修改后,设置为个性化格式化模板。

    它还有许多配置项如文件保存时自动排序, CSS 自定义规则格式化等等,可以在官网 (opens new window)查阅

    注意: 一定要在 setting.json 里加入配置 "csscomb.preset": "zen",插件才能生效, 因为它的默认值为"{}"。

    上次更新: 2023/04/05, 09:41:10
    BEM:class命名规范
    TypeScript Tips

    ← BEM:class命名规范 TypeScript Tips→

    最近更新
    01
    JavaScript-test
    07-20
    02
    二维码的原理
    07-20
    03
    利用ChatGPT优化代码
    07-20
    更多文章>
    Theme by Vdoing | Copyright © 2021-2025 XingYun | MIT License
    • 跟随系统
    • 浅色模式
    • 深色模式
    • 阅读模式