Less 编码规范

简介

因为自己最近写css用的比较多还是less,整理了一份less规范,

代码组织

代码按如下形式按顺序组织:

  1. @import
  2. 变量声明
  3. 样式声明
  1. // ✓
  2. @import "est/all.less";
  3.  
  4. @default-text-color: #333;
  5.  
  6. .page {
  7. width: 960px;
  8. margin: 0 auto;
  9. }

@import 语句

@import 语句引用的文件写在一对引号内,.less 后缀省略(与引入 CSS 文件时的路径格式一致)。引号使用 ' 和 " 均可。

  1. // ✗
  2. @import 'est/all';
  3. @import "my/mixins.less";
  4.  
  5. // ✓
  6. @import "est/all.less";
  7. @import "my/mixins.less";

空格

属性、变量

选择器和 { 之间保留一个空格。

属性名后的冒号(:)与属性值之间保留一个空格,冒号前保留空格。

定义变量时冒号(:)与变量值之间保留一个空格,冒号前保留空格。

在用逗号(,)分隔的列表(Less 函数参数列表、以 , 分隔的属性值等)中,逗号后保留一个空格,逗号前保留空格。

  1. // ✗
  2. .box{
  3. @w:50px;
  4. @h :30px;
  5. width:@w;
  6. height :@h;
  7. color: rgba(255,255,255,.3);
  8. transition: width 1s,height 3s;
  9. }
  10.  
  11. // ✓
  12. .box {
  13. @w: 50px;
  14. @h: 30px;
  15. width: @w;
  16. height: @h;
  17. transition: width 1s, height 3s;
  18. }
  1. 运算

+ / - / * / / 四个运算符两侧保留一个空格。+ / - 两侧的操作数有相同的单位,如果其中一个是变量,另一个数值书写单位。

  1. // ✗
  2. @a: 200px;
  3. @b: (@a+100)*2;
  4.  
  5. // ✓
  6. @a: 200px;
  7. @b: (@a + 100px) * 2;

混入(Mixin)

Mixin 和后面的空格之间包含空格。在给 mixin 传递参数时,在参数分隔符(, / ;)后保留一个空格:

  1. // ✗
  2. .box {
  3. .size(30px,20px);
  4. .clearfix ();
  5. }
  6.  
  7. // ✓
  8. .box {
  9. .size(30px, 20px);
  10. .clearfix();
  11. }

选择器

当多个选择器共享一个声明块时,每个选择器声明独占一行。

  1. // ✗
  2. h1, h2, h3 {
  3. font-weight:;
  4. }
  5.  
  6. // ✓
  7. h1,
  8. h2,
  9. h3 {
  10. font-weight:;
  11. }

Class 命名不得以样式信息进行描述,如 .float-righttext-red 等。


省略与缩写

缩写

多个属性定义可以使用缩写时, 尽量使用缩写。缩写更清晰字节数更少。常见缩写有 marginborderpaddingfontlist-style 等。在书写时考量缩写展开后是否有不需要覆盖的属性内容被修改,从而带来副作用。

数值

对于处于 (0, 1) 范围内的数值,小数点前的 0 可以(MAY)省略,同一项目中保持一致。

  1. // ✗
  2. transition-duration: 0.5s, .7s;
  3.  
  4. // ✓
  5. transition-duration: .5s, .7s;

0 值

当属性值为 0 时,省略可省的单位(长度单位如 pxem,不包括时间、角度等如 sdeg)。

  1. // ✗
  2. margin-top: 0px;
  3.  
  4. // ✓
  5. margin-top: 0;

颜色

颜色定义使用 #rrggbb 格式定义,并在可能时尽量缩写为 #rgb 形式,且避免直接使用颜色名称与 rgb() 表达式。

  1. // ✗
  2. border-color: red;
  3. color: rgb(254, 254, 254);
  4.  
  5. // ✓
  6. border-color: #f00;
  7. color: #fefefe;

私有属性前缀

同一属性有不同私有前缀的,尽量(按前缀长度降序书写,标准形式写在最后。且这一组属性以第一条的位置为准,尽量按冒号的位置对齐。

  1. // ✓
  2. .box {
  3. -webkit-transform: rotate(30deg);
  4. -moz-transform: rotate(30deg);
  5. -ms-transform: rotate(30deg);
  6. -o-transform: rotate(30deg);
  7. transform: rotate(30deg);
  8. }

其他

可以在无其他更好解决办法时使用 CSS hack,并且尽量使用简单的属性名 hack 如 _zoom*margin

可以但谨慎使用 IE 滤镜。需要注意的是,IE 滤镜中图片的 URL 是以页面路径作为相对目录,而不是 CSS 文件路径。


嵌套和缩进

嵌套的声明块前增加一次缩进,有多个声明块共享命名空间时尽量嵌套书写,避免选择器的重复。

但是需注意的是,尽量仅在必须区分上下文时才引入嵌套关系(在嵌套书写前先考虑如果不能嵌套,会如何书写选择器)。

  1. // ✗
  2. .main .title {
  3. font-weight:;
  4. }
  5.  
  6. .main .content {
  7. line-height: 1.5;
  8. }
  9.  
  10. .main {
  11. .warning {
  12. font-weight:;
  13. }
  14.  
  15. .comment-form {
  16. #comment:invalid {
  17. color: red;
  18. }
  19. }
  20. }
  21.  
  22. // ✓
  23. .main {
  24. .title {
  25. font-weight:;
  26. }
  27.  
  28. .content {
  29. line-height: 1.5;
  30. }
  31.  
  32. .warning {
  33. font-weight:;
  34. }
  35. }
  36.  
  37. #comment:invalid {
  38. color: red;
  39. }

变量

Less 的变量值总是以同一作用域下最后一个同名变量为准,务必注意后面的设定会覆盖所有之前的设定。

变量命名)采用 @foo-bar 形式,使用 @fooBar 形式。

  1. // ✗
  2. @sidebarWidth: 200px;
  3. @width:800px;
  4.  
  5. // ✓
  6. @sidebar-width: 200px;
  7. @width: 800px;

继承

使用继承时,如果在声明块内书写 :extend 语句,写在开头:

  1. // ✗
  2. .sub {
  3. color: red;
  4. &:extend(.mod all);
  5. }
  6.  
  7. // ✓
  8. .sub {
  9. &:extend(.mod all);
  10. color: red;
  11. }

混入(Mixin)

在定义 mixin 时,如果 mixin 名称不是一个需要使用的 className,加上括号,否则即使不被调用也会输出到 CSS 中。

  1. // ✗
  2. .big-text {
  3. font-size: 2em;
  4. }
  5.  
  6. h3 {
  7. .big-text;
  8. }
  9.  
  10. // ✓
  11. .big-text() {
  12. font-size: 2em;
  13. }
  14.  
  15. h3 {
  16. .big-text();
  17. }

如果混入的是本身不输出内容的 mixin,在 mixin 后添加括号(即使不传参数),以区分这是否是一个 className(修改以后是否会影响 HTML)。

  1. // ✗
  2. .box {
  3. .clearfix;
  4. .size (20px);
  5. }
  6.  
  7. // ✓
  8. .box {
  9. .clearfix();
  10. .size(20px);
  11. }

Mixin 的参数分隔符使用 , 和 ; 均可,但在同一项目中保持统一。


命名空间

变量和 mixin 在命名时遵循如下原则:

  • 一个项目只能引入一个无命名前缀的基础样式库(如 est)
  • 业务代码和其他被引入的样式代码中,变量和 mixin 必须有项目或库的前缀

字符串

在进行字符串转义时,使用 ~"" 表达式与 e() 函数均可,但在同一项目中保持一致。

字符串两侧的引号使用 "


注释

单行注释尽量(SHOULD)使用 // 方式。

  1. // Hide everything
  2. * {
  3. display: none;
  4. }

less编码规范的更多相关文章

  1. Android的编码规范

    一.Android编码规范 1.学会使用string.xml文件 在我看来,当一个文本信息出现的次数大于一次的时候就必须要使用string.xml 比如一个保存按钮 , 不规范写法: <Butt ...

  2. PHP 高级编程(1/5) - 编码规范及文档编写

    PHP 高级程序设计学习笔记20140612 软件开发中的一个重要环节就是文档编写.他可以帮助未来的程序维护人员和使用者理解你在开发时的思路.也便于日后重新查看代码时不至于无从下手.文档还有一个重要的 ...

  3. 【原】JAVA SE编码规范

    /* * 编码规范: * 1.所有的命名遵循"见名知意"的原则 * 2.所有的命名不允许使用汉字或拼音 * 3.Java的工程命名建议使用小写,比如:oa.crm.cms... * ...

  4. 浅谈Android编码规范及命名规范

    前言: 目前工作负责两个医疗APP项目的开发,同时使用LeanCloud进行云端配合开发,完全单挑. 现大框架已经完成,正在进行细节模块上的开发 抽空总结一下Android项目的开发规范:1.编码规范 ...

  5. PHP编码规范PSR-2

    .note-content { font-family: "Helvetica Neue", Arial, "Hiragino Sans GB", STHeit ...

  6. Objective-C开发编码规范【转载】

    概要 Objective-C是一门面向对象的动态编程语言,主要用于编写iOS和Mac应用程序.关于Objective-C的编码规范,苹果和谷歌都已经有很好的总结: Apple Coding Guide ...

  7. 前端编码规范之CSS

    "字是门面书是屋",我们不会去手写代码,但是敲出来的代码要好看.有条理,这还必须得有一点约束~ 团队开发中,每个人的编码风格都不尽相同,有时候可能存在很大的差异,为了便于压缩组件对 ...

  8. 前端编码规范之JavaScript

    上次浅谈了下关于CSS的编码规范,大部分童鞋持赞同意见,仍存在一些童鞋不太理解这些规范的意义. 如果是个人或者小作坊开发,其实这些所谓的编码规范也没啥意思,因为大家写好的代码直接就给扔到网上去了,很少 ...

  9. Java Script 编码规范【转】

    Java Script 编码规范 以下文档大多来自: Google JavaScript 编码规范指南 Idiomatic 风格 参考规范 ECMAScript 5.1 注解版 EcmaScript ...

  10. python编码规范

    python编码规范 文件及目录规范 文件保存为 utf-8 格式. 程序首行必须为编码声明:# -*- coding:utf-8 -*- 文件名全部小写. 代码风格 空格 设置用空格符替换TAB符. ...

随机推荐

  1. vs2015 Xamarin.Android安装

    原文:vs2015 Xamarin.Android安装 Xamarin.Android 安装步骤,以vs2015为例 1,安装vs2015中的跨平台项,但是安装在国内肯定失败,因为需要到谷歌下载 当我 ...

  2. Android 使用WakeLock

           为了延长电池的使用寿命,Android设备会在一段时间后使屏幕变暗,然后关闭屏幕显示,最后停止CPU.WakeLock是一个电源管理系统服务功能,应用程序可以使用它来控制设备的电源状态. ...

  3. ColorFilter类

    以前没用到过LightingColorFilter这个类 ,google了下 @Override protected void onDraw(Canvas canvas) { int mul = 0x ...

  4. nyist 61 传纸条 nyist 712 探 寻 宝 藏(双线程dp问题)

    http://acm.nyist.net/JudgeOnline/problem.php?pid=61 http://acm.nyist.net/JudgeOnline/problem.php?pid ...

  5. python-os.walk目录递归

    递归删除文件或目录: 递归,os.walk 删除目录,shutil.rmtree # -*- coding: UTF-8 -*- import os.path,sys,shutil path = 'H ...

  6. 《Spark大数据处理:技术、应用与性能优化 》

    基本信息 作者: 高彦杰 丛书名:大数据技术丛书 出版社:机械工业出版社 ISBN:9787111483861 上架时间:2014-11-5 出版日期:2014 年11月 开本:16开 页码:255 ...

  7. 将eclipse新建项目的默认编码GBK改为UTF-8

    在eclipse下: 新建项目默认编码设置:Window->Preferences->General->Workspace->Text file encoding 将其改为UF ...

  8. StorSimple 简介

     2014年 10月 28日,星期二 PRACHEETI NAGARKAR DESAI 混合云存储业务资深项目经理 在此我很荣幸地宣布StorSimple解决方案已经在中国正式上市.该方案为IT部 ...

  9. linux下阅读源代码的工具

    说来真是惭愧呀.一直在用VIM 做开发.却不知道VI 里还有这么好使的工具.以前一直都是用: find -type f -print | xargs grep -i **** 在源代码里查找. 原来L ...

  10. HDU 5961 传递 【图论+拓扑】 (2016年中国大学生程序设计竞赛(合肥))

    传递 Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)     Problem ...