如何编写规范,灵活,稳定,高质量的HTML和css代码 - 兜兜里有糖哦
黄金定律
永远遵循同一套编码规范,不管有多少人共同参与同一项目,一定要确保每一行代码都像是同一个人编写的.
语法:
1.用两个空格来代替制表符(tab);2.嵌套元素应当缩进一次(两个空格); 3.对于属性的定义,确保全部使用双引号,绝不要使用单引号; 4.不要在自闭合元素的尾部添加斜线--HTML5规范(https://dev.w3.org/html5/spec-author-view/syntax.html#syntax-start-tag)中明确说明这是可选的; 5.不要省略可选的结束标签;6.为每个HTML页面的第一行添加标准模式的声明,这样能确保在每个浏览器中有一只的展现;
语言属性:
根据HTML5规范,建议为HTML根元素指定 lang 属性,从而为文本设置正确的语言.这将有助于语音合成工具确定其应该采用的发音,有助于翻译工具确定翻译时应遵守的规则等等.lang 属性列表:http://www.sitepoint.com/web-foundations/iso-2-letter-language-codes/
IE兼容模式:
IE支持通过特定的标签来确定回执当前页面所应该采用的IE版本.除非有强烈要求,否则最好是设置为edge mode,从而统治IE采用其所支持的最新的模式.
字符编码:
通过声明字符编码,能够确保浏览器快速并容易的判断页面内容的渲染方式.这样做可以避免在HTML中使用字符实体标记,从而全部与文档编码一致.
引入css和JavaScript文件:
根据HTML5规范,再引入css和JavaScript文件时一般不需要指定type属性,因为text/css和text/javascript分别是他们的默认值.
实用为王:
尽量遵循HTML标准和语义,但是不要以牺牲实用性为代价.任何时候都要尽量使用最少的标签并保持最小的复杂度.
属性顺序:
HTML属性应当按照以下顺序依次排列,确保代码的易读性:
1.class2.id,name 3.data-* 4.src,for,type,href 5.title,alt 6.Aria,role class用于标示高度可复用的组件,因此应该排在首位.
减少标签的数量
编写HTML代码时,尽量避免多余的父元素.很多时候,这需要迭代和重构来实现.
JavaScript生成的标签
通过JavaScript生成的标签让内容变得不易查找、编辑,并且境地性能.能避免是尽量避免.
CSS语法:
1.用两个空格来代替制表符(tab); 2.为选择器分组时,将单独的选择器单独放在一行; 3.为了代码的易读性,在每个声明块的左花括号钱添加一个空格; 4.声明块的右花括号应该单独成行; 5.每条声明语句的 : 后面应该插入一个空格; 6.为了获得更准确的错误报告,每条声明都应该独占一行; 7.所有声明语句都应该以分号结尾,最后一条声明语句后面的分号是可选的,但是如果省略这个分号,代码可能更容易出; 8.对于以逗号分隔的属性值,每个逗号后面都应该插入一个空格; 9.对于属性值或颜色参数,省略小于1的小数前面的0(例如 .5代替0.5); 10.十六进制值应该全部小写,例如:#fff,尽量使用简写形式的十六进制值,例如用#fff代替#ffffff; 11.为选择其中的属性添加双引号,例如 input[type="text"]; 12.避免为 0 值指定单位,例如用margin:0 代替margin:0px.
声明顺序:
相关的属性声明应该归为一组,并且按照下面的顺序排列:
1.positioning(position: absolute; top: 0; bottom: 0; right: 0; left: 0; z-index: 100;); 2.box model(display: block; float: left; width: 100px; height: 100px;); 3.typographic(font: normal 13px "Microsoft YaHei"; line-height: 1.5em; color: #333; text-align:center;); 4.visual(background: yellow; border: 1px solid #c00; border-radius: 3px; opacity: 1; ); 由于定位(positioning)可以从正常的文档流中移除元素,并且还能覆盖盒模型(box model)相关的样式,因此排在首位.盒模型排在第二位,因为他决定了组建的尺寸和位置.其他属性知识影响组建的内部(inside)或者是不影响前两组属性,因此排在后面.参考http://twitter.github.io/recess/
不要使用@import
与标签相比,@import指令要慢很多,不光增加了额外的请求次数,还会导致不可预料的问题.替代办法有一下几种:
1.使用多个元素; 2.通过sass或less类似的css预处理器将多个css文件便以为一个文件; 3.通过rails、jekyll或者其他系统中提供过css文件合并功能.
媒体查询(media query)的位置
将媒体查询尽可能放在相关规则的附近.不要将他们打包放在一个单一样式文件中或者放在文档底部.
带前缀的属性:
当使用特定厂商的带前缀的属性时,通过锁紧的方式,让每个属性的值在垂直方向对齐,这样方便多行编辑.例如: .selector {
-webkit-box-shadow: 0 1px 2px rgba(0,0,0,.15);
box-shadow: 0 1px 2px rgba(0,0,0,.15);
}
单行规则声明:
对于值包含一条声明的样式,为了易读性和便于快速编辑,建议将语句放在同一行.对于带有多条声明的样式,还是应当将声明分为多行.这样做的关键因素是为了错误检测.例如css校验器之处在180行有语法错误,如果是单行单条声明,你就不会忽略这个错误,如果是单行多条声明的话,你就要仔细分析避免漏掉错误了.
Less和Sass中的嵌套
避免非必要的嵌套.这是因为虽然你可以使用嵌套,但是并不意味着应该使用嵌套.只有在必须将样式限制在父元素内(也就是后代选择器),并且存在多个需要嵌套的元素师才能使用嵌套.
注释:
代码是由人编写并维护的.请确保你的代码能够自描述、注释良好并且易于他人理解.好的代码注释能够传递上下文关系和代码目的;
不要简单地重申组件或者class名称;对于较长的注释,务必书写完整的句子,对于一般性的注释,可以书写简介的短语.
class命名
class名称中只能出现谢小字符和破折号(不是下划线也不是驼峰命名法).破折号应当用于相关class的命名(类似命名空间,例如.btn和.btn-danger)避免过度任意的简写. .btn代表button,但是.s不能表达任何意思; class名应该尽可能短,并且意义明确; 使用有意义的名称,使用有组织的或者目的明确的名称,不要使用表现形式的名称; 基于最近的class或者基本class作为新class的前缀; 使用.js-* class来标识行为(与样式相对),并且不要将这些class包含到css文件中; 在为sass和less变量命名时也可以参考上面列出的各项规范.
选择器
对于通用元素使用class,这样利于渲染性能的优化; 对于经常出现的组件,避免使用属性选择器(例如:[class^="···"]),浏览器的性能会受到这些因素的影响; 选择器尽可能短,并且尽量限制组成选择器的元素个数,建议不要超过3个; 只有在必要的时候才将class限制在最近的父元素内.
代码组织:
以组建为单位组织代码段; 指定一致的注释规范; 使用一致的空白符将代码分隔成块,这样利于扫描较大的文档; 如果使用了多个css文件,将其按照组件而不是页面的形式拆分,因为页面会被重组,而组件只会被移动. 文章来源:http://www.css88.com/doc/codeguide/

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

當物件在Jackson庫中具有父子關係時,將使用@JsonIdentityInfo註解。 @JsonIdentityInfo 註解 用於在序列化和反序列化過程中指示物件身分。 ObjectIdGenerators.PropertyGenerator是一個抽象佔位符類,用來表示要使用的物件識別碼來自POJO屬性的情況。語法@Target(value={ANNOTATION_TYPE,TYPE,FIELD,METHOD,PARAMETER})@Retention(value=RUNTIME)public

PHP演算法的基本概念與應用隨著互聯網的快速發展,PHP作為一種簡單易學且功能強大的程式語言,在Web開發中得到了廣泛應用。而演算法作為計算機科學的基礎,對於解決問題和最佳化程序起著至關重要的作用。本文將介紹PHP演算法的基本概念,並提供一些實際應用的程式碼範例。一、演算法的基本概念演算法的定義演算法是解決特定問題的有限序列的一種描述。它包括一系列的步驟和規則,按照特定的順

在Laravel監控錯誤方面,是提升應用穩定性的重要一環。在開發過程中,難免會遇到各種錯誤,而如何及時發現並解決這些錯誤,是保障應用正常運作的關鍵之一。 Laravel提供了豐富的工具和功能來幫助開發者監控和處理錯誤,本文將介紹其中一些重要的方法,並附上具體的程式碼範例。一、使用日誌記錄日誌記錄是監控錯誤的重要手段之一。 Laravel內建了強大的日誌系統,開發者

很多用戶都會遇到在操作電腦的時候卡頓或者是藍屏,這個時候我們就需要找一個最為穩定的win10版本來進行操作,整體都是非常的好用的,可以讓你日常使用更為流暢。史上最穩定的win10版本1、win10正版原廠系統在這裡用戶可以使用簡單的操作,系統經過優化,具有很強的穩定性、安全性、兼容性,用戶可以按照步驟實現完美機器2、俄羅斯大神精簡版win10經過嚴格的精簡操作,刪除了許多不必要的功能和服務。精簡後,系統的CPU和記憶體佔用率更低,運作速度更快。 3.win10精簡版1909安裝多台不同硬體型號的電腦

Python為什麼如此受歡迎?探討Python在程式設計領域的優勢,需要具體程式碼範例Python作為一種高級程式語言,自問世之日起便備受程式設計師們的喜愛與推崇。究其原因,不僅是因為它的簡潔、易讀和強大的功能,更因為它在各個領域都展現了無可比擬的優勢。本文將探討Python在程式設計領域的優勢,並透過具體的程式碼範例來解釋為什麼Python如此受歡迎。首先,Pytho

眾所周知,我們現在去買的新電腦打開之後安裝的系統全部都是windows10系統。有的小夥伴不懂是為什麼,對於這個問題,小編覺得現在win10已經是市面上主流的作業系統,以後使用win10將是大勢所趨。微軟也即將在2020年停止win7系統的更新。由此說明win10在以後將是普及社會的作業系統。為什麼新買的電腦都裝windows10在我看來,出現這種情況的關鍵因素在於,從英特爾第六代處理器乃至更高一級的衍生型號開始,與具備100系列及更新款主機板相容的產品均內建了新型號XHCI主控接口,因此並不

Golang泛型探密:支持與限制分析一、引言隨著Go語言的不斷發展,社區對於泛型的需求也日益增大。在過去的幾年間,Golang社群一直在討論是否應該為Go添加泛型支援。泛型是一種程式設計範式,可以提高程式碼的複用性、可讀性和可維護性。本文將探討Golang最新泛型支援的情況,以及其支援與限制的分析,並透過具體的程式碼範例來說明。二、泛型支持的情況

PHP是一種廣泛使用的程式語言,它在許多網站和應用程式的開發中起著重要的作用。最近,PHP推出了8.3版本的更新,這個版本帶來了許多令人興奮的新功能和改進,使得PHP更加安全和穩定。首先,PHP8.3引入了一種稱為Fibers的新特性。 Fibers是一種輕量級的協程實現,它使得在單一請求處理過程中能夠暫停和恢復執行。這種機制可以提高性能和可擴展性,因為它消
