찾다
웹 프론트엔드HTML 튜토리얼如何编写规范,灵活,稳定,高质量的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/

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
Win10的最稳定版本Win10的最稳定版本Dec 25, 2023 pm 07:58 PM

很多用户都会遇到在操作电脑的时候卡顿或者是蓝屏,这个时候我们就需要找一个最为稳定的win10版本来进行操作,整体都是非常的好用的,可以让你日常使用更为流畅。史上最稳定的win10版本1、win10正版原装系统在这里用户可以使用简单的操作,系统经过优化,具有很强的稳定性、安全性、兼容性,用户可以按照步骤实现完美机器2、俄罗斯大神精简版win10经过严格的精简操作,删除了很多不必要的功能和服务。精简后,系统的CPU和内存占用率更低,运行速度更快。3、win10精简版1909安装多台不同硬件型号的电脑

@JsonIdentityInfo注解在Java中使用Jackson的重要性是什么?@JsonIdentityInfo注解在Java中使用Jackson的重要性是什么?Sep 23, 2023 am 09:37 AM

当对象在Jackson库中具有父子关系时,将使用@JsonIdentityInfo注释。@JsonIdentityInfo 注解 用于在序列化和反序列化过程中指示对象身份。ObjectIdGenerators.PropertyGenerator是一个抽象占位符类,用于表示要使用的对象标识符来自POJO属性的情况。语法@Target(value={ANNOTATION_TYPE,TYPE,FIELD,METHOD,PARAMETER})@Retention(value=RUNTIME)public

PHP算法的基本概念与应用PHP算法的基本概念与应用Jul 07, 2023 pm 05:22 PM

PHP算法的基本概念与应用随着互联网的快速发展,PHP作为一种简单易学且功能强大的编程语言,在Web开发中得到了广泛应用。而算法作为计算机科学的基础,对于解决问题和优化程序起着至关重要的作用。本文将介绍PHP算法的基本概念,并提供一些实际应用的代码示例。一、算法的基本概念算法的定义算法是解决特定问题的有限序列的一种描述。它包括一系列的步骤和规则,按照特定的顺

为什么如今新买的电脑普遍选用Windows 10操作系统?为什么如今新买的电脑普遍选用Windows 10操作系统?Jan 09, 2024 pm 03:37 PM

众所周知,我们现在去买的新电脑打开之后安装的系统全部都是windows10系统。有的小伙伴不明白是为什么,对于这个问题,小编觉得现在win10已经是市面上主流的操作系统,以后使用win10将是大势所趋。微软也即将在2020年停止对win7系统的更新。由此说明win10在以后将是普及社会的操作系统。为什么新买的电脑都装windows10在我看来,出现这种情况的关键因素在于,从英特尔第六代处理器乃至更高一级的衍生型号开始,与具备100系列及更新款主板兼容的产品均内置了新型号XHCI主控接口,因此并不

Laravel监控错误:提升应用稳定性Laravel监控错误:提升应用稳定性Mar 06, 2024 pm 04:48 PM

在Laravel监控错误方面,是提升应用稳定性的重要一环。在开发过程中,难免会遇到各种错误,而如何及时发现并解决这些错误,是保障应用正常运行的关键之一。Laravel提供了丰富的工具和功能来帮助开发者监控和处理错误,本文将介绍其中一些重要的方法,并附上具体的代码示例。一、使用日志记录日志记录是监控错误的重要手段之一。Laravel内置了强大的日志系统,开发者

从不同角度看C语言和Python的对比从不同角度看C语言和Python的对比Mar 18, 2024 am 10:57 AM

C语言和Python是两种常见的编程语言,各自具有特点和优势。本文将从不同的角度对比这两种语言,分析它们在不同场景下的适用性和优劣势。1.语法简洁性C语言是一种底层语言,语法相对较为繁琐,需要手动管理内存、声明变量等。举例来说,编写一个简单的HelloWorld程序,C语言代码如下:#includeintmain()

Python为什么如此受欢迎?探究Python在编程领域的优势Python为什么如此受欢迎?探究Python在编程领域的优势Mar 26, 2024 am 09:15 AM

Python为什么如此受欢迎?探究Python在编程领域的优势,需要具体代码示例Python作为一种高级编程语言,自问世之日起便备受程序员们的喜爱与推崇。究其原因,不仅仅是因为它的简洁、易读和强大的功能,更因为它在各个领域都展现出了无可比拟的优势。本文将探究Python在编程领域的优势,并通过具体的代码示例来解释为什么Python如此受欢迎。首先,Pytho

win系统最好用流畅稳定的版本推荐win系统最好用流畅稳定的版本推荐Jan 07, 2024 pm 12:18 PM

当我们面对微软公司推出的众多系统以及分支版本进行选择安装的时候,详细很多小伙伴都想装一个最稳定流畅的操作系统来进行安装。那么对于windows系统哪个版本最好用这个问题,小编觉得这些版本区别都是在于功能上,至于哪个好用还是要看个人的喜好还有需求了。详细内容就来看下小编是怎么说的吧~windows系统哪个版本最好用流畅稳定答:目前win10系统是最好用,最流畅稳定的系统。1、windows10版本的操作系统是目前主流也是最新的系统。2、这个系统更新了很多新的人性化功能以及修改了之前系统的缺陷。3、

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경