웹 프론트엔드 HTML 튜토리얼 11个让你代码整洁的原则 - jerrylsxu

11个让你代码整洁的原则 - jerrylsxu

May 22, 2016 pm 05:19 PM

<p class="FocusMe">写Web页面就像我们建设房子一样,地基牢固,房子才不会倒。同样的,我们制作Web页面也一样,一个良好的HTML结构是制作一个美丽的网站的开始,同样的,良好的CSS只存在同样良好的HTML中,所以一个干净的,语义的HTML的优点很多,那么平时制作中,我们做到了这一点吗?我们一起来看一张图片:</p> <p class="FocusMe"><img src="/static/imghw/default1.png" data-src="http://www.admin10000.com/UploadFiles/Document/201207/13/20120713140824123808.PNG" class="lazy" alt=""></p> <p class="FocusMe">  上图展示了两段代码,我想大家都只会喜欢第一种,我们先不说其语义,至少他的结构让我们看上去清爽,而第二种呢?一看就是糟糕的代码的代码,让人讨厌的代码。那么要怎么样才能写出一个好的代码,整洁的代码呢?下面我们就从以下十二个方面一起来学习,只要大家以后在写代码的时候能坚持下面的十二个原则,保准你的代码质量能上去,而且你写的代码会人见人爱。</p> <p class="FocusMe"><strong>  一、DOCTYPE的声明</strong></p> <p class="FocusMe">  如果我们想做好一件事情,首先要知道我们有哪些权利去做,就如“DOCTYPE”的声明,我们没有必要去讨论是否使用HTML4.01或者XHTML1.0或者说现在的HTML5都提供了严格版本或者过渡版本,这些都能很好的支持我们写的代码:</p> <p class="FocusMe"><img src="/static/imghw/default1.png" data-src="http://www.admin10000.com/UploadFiles/Document/201207/13/20120713140824641125.PNG" class="lazy" alt=""></p> <p class="FocusMe">  由于我们现在的布局不需要table布局也能做出很好的布局,那么我们就可以考虑不使用过渡型而使用严格型的“DOCTYPE”,为了向后兼容,我建议使用HTML5的声明模式:</p> <p class="FocusMe"></p> <p class="FocusMe"></p> <p class="FocusMe">  如果想了解更多这方面的知识,可以点击:</p> <ol class=" list-paddingleft-2"> <li><p><a href="http://www.w3.org/QA/2002/04/valid-dtd-list.html" target="_blank">W3C: Recommended DTDs to use in your Web document</a></p></li> <li><p><a href="http://www.alistapart.com/stories/doctype/" target="_blank">Fix Your Site With the Right DOCTYPE!</a></p></li> <li><p><a href="http://www.456bereastreet.com/archive/200609/no_more_transitional_doctypes_please/" target="_blank">No more Transitional DOCTYPEs, please</a></p></li> </ol> <p class="FocusMe"><strong>  二、字符集和编码字符</strong></p> <p class="FocusMe">  在每个页面的开始中,我们都在</p> <p><br></p> <p class="syntaxhighlighter xml"></p> <table border="0"><tbody><tr class="firstRow"> <td class="gutter"><p class="line number1 index0 alt2">1</p></td> <td class="code"> <p class="container"><br></p> <p class="line number1 index0 alt2"><code class="xml plain"><</code><code class="xml keyword">meta</code> <code class="xml color1">charset</code><code class="xml plain">=</code><code class="xml string">"UTF-8"</code> <code class="xml plain">/></code></p> </td> </tr></tbody></table> <p></p> <p class="FocusMe">  而且我们在平时写页面中时,时常会碰到"&"这样的符号,那么我们不应该直接在页面这样写“&”:</p> <p class="FocusMe"><img src="/static/imghw/default1.png" data-src="http://www.admin10000.com/UploadFiles/Document/201207/13/20120713140824467393.PNG" class="lazy" alt=""></p> <p class="FocusMe">  我们应该在代码中使用字符编码来实现,比如说“&”我们在代码中应该使用“&”来代替他。</p> <p class="FocusMe">  如果想了解更多这方面的知识,可以点击:</p> <ol class=" list-paddingleft-2"> <li><p><a href="http://en.wikipedia.org/wiki/UTF-8" target="_blank">Wikipedia: UTF-8</a></p></li> <li><p><a href="http://www.cs.tut.fi/~jkorpela/chars.html" target="_blank">A tutorial on character code issues</a></p></li> <li><p><a href="http://www.ascii-code.com/" target="_blank">The Extended ASCII table</a></p></li> </ol> <p class="FocusMe"><strong>  三、正确的代码缩进</strong></p> <p class="FocusMe">  在页面编辑中,代码的缩进有没有正确,他不会影响你网站的任何功能,但要是你没有一个规范的缩进原则,让读你代码的人是非常的生气,所以说正确的代码缩进可以增强你的代码可读性。标准程序的缩进应该是一个制表符(或几个空格),形像一点的我们来看下文章开头那张图,或者一起来看下面展示的这张图,你看后就知道以后自己的代码要怎么样书写才让人看了爽:</p> <p class="FocusMe"><img src="/static/imghw/default1.png" data-src="http://www.admin10000.com/UploadFiles/Document/201207/13/20120713140824239583.PNG" class="lazy" alt=""></p> <p class="FocusMe">  不用说,大家都喜欢下面的那种代码吧。这只是一个人的习惯问题,不过建议从开始做好,利人利已。有关于这方面的介绍,大家还可以参考:<a href="http://www.w3.org/People/Raggett/tidy/" target="_blank">Clean up your Web pages with HTML TIDY</a>。</p> <p class="FocusMe"><strong>  四、外链你的CSS样式和Javascript脚本</strong></p> <p class="FocusMe">  页面中写入CSS样式有很多种方法,有些直接将样式放入页面的“</p> <p class="FocusMe"><img src="/static/imghw/default1.png" data-src="http://www.admin10000.com/UploadFiles/Document/201207/13/20120713140824009862.PNG" class="lazy" alt=""></p> <p class="FocusMe">  上面我们所说的只是样式,其实javascript脚本也和CSS样式是同一样的道理。图文并说,我最终想表达的意思是“<strong>在制作web页面中,尽量将你的CSS样式和javascript脚本单独放在一个文件中,然后通过链接的方式引用这些文件,这样做的最大好处是,方便你的样式和脚本的管理与修改</strong>。”</p> <p class="FocusMe"><strong>  五、正确的标签嵌套</strong></p> <p class="FocusMe">  我们在写HTML时总是需要标签的层级嵌套来帮我们完成HTML的书写,但这些HTML的嵌套是有一定的规则的,如果要细说的话,我们可能要用几个章节来描述,那么我今天这里要说的是,我们在写HTML时不应该犯以下这样的超级错误:</p> <p class="FocusMe"><img src="/static/imghw/default1.png" data-src="http://www.admin10000.com/UploadFiles/Document/201207/13/20120713140824325977.PNG" class="lazy" alt=""></p> <p class="FocusMe">  上图的结构我们是常见的,比如说首页的标题,那么我们就应该注意了,不能把“</p> <h1>”放在“<a>”标签中,换句话说,就是不能么块元素和在行内元素中。上面只是一个例子,只是希望大家在平时的制作中不应该犯这样的超级错误。</a> </h1> <p></p> <p class="FocusMe"><strong>  六、删除不必要的标签</strong></p> <p class="FocusMe">  首先我们一起来看一个实例的截图:</p> <p class="FocusMe"><img src="/static/imghw/default1.png" data-src="http://www.admin10000.com/UploadFiles/Document/201207/13/20120713140824722293.PNG" class="lazy" alt=""></p> <p class="FocusMe">  上图明显是一个导航菜单的制作,在上图的实例中:有一个“p#topNav”包住了列表“ul#bigBarNavigation”,而“p”和“ul”列表都是块元素,加上“p”此处用来包“ul”根本就没有起到任何作用。虽然“p”的出现给我们制作web页面带来了极大的好处,但我们也没有必要到处这样的乱用,不知道大家平时有没有注意这样的细节呢?我是犯这样的错误,如果你也有过这样的经历,那么从今天开始,从现在开始,我们一起努力来改正这样的错误。</p> <p class="FocusMe">  有关于如何正确的使用标签,大家感兴趣的话可以点击:<a href="http://csscreator.com/?q=pitis" target="_blank">Divitis: what it is, and how to cure it.</a></p> <p class="FocusMe"><strong>  七、使用更好的命名</strong></p> <p class="FocusMe">  这里所说的命名就是给你的页面中相关元素定义类名或者是ID名,很多同学都有这栗的习惯,比如说有一个元素字体是红色的,给他加上“red”,甚至布局都写“left-sidebar”等,但是你有没有想过,如果这个元素定义了“red”后,过几天客户要求使用“蓝色”呢?或者又说,那时的“left-sidebar”边栏此时不想放在左边了,而是想放在右边,那么这样一来我们前面的命名可以说是一点意义都没有了,正如下面的一个图所示:</p> <p class="FocusMe"><img src="/static/imghw/default1.png" data-src="http://www.admin10000.com/UploadFiles/Document/201207/13/20120713140824526317.PNG" class="lazy" alt=""></p> <p class="FocusMe">  那么定义一个好的名就很得要了,不但自己能看懂你的代码,而且别人也能轻松读懂你的代码,比如说一个好的类名和ID名“mainNav”、“subNav”、“footer”等,他能描述所包含的事情。不好的呢,比如前面所说的。</p> <p class="FocusMe">如果想了解更多这方面的知识,可以点击:</p> <ol class=" list-paddingleft-2"> <li><p><a href="http://www.techrepublic.com/article/standardizing-css-class-and-id-names/5286783" target="_blank">Standardizing CSS class and id names</a></p></li> <li><p><a href="http://sixrevisions.com/css/css-tips/css-tip-2-structural-naming-convention-in-css/" target="_blank">CSS Tip #2: Structural Naming Convention in CSS</a></p></li> <li><p><a href="http://woork.blogspot.com/2008/11/css-coding-semantic-approach-in-naming.html" target="_blank">CSS coding: semantic approach in naming convention</a></p></li> <li><p><a href="http://www.realdealmarketing.net/docs/css-coding-style.php" target="_blank">CSS Naming Conventions and Coding Style</a></p></li> </ol> <p class="FocusMe"><strong>  八、离开版本的CSS</strong></p> <p class="FocusMe">  我们在设计菜单时,有时要求所有菜单选项的文本全部大写,大家平时是不是直接在HTML标签中就将他们设置成大写状态呢?如果是的话,我觉得不好,如果为了将来具有更好的扩展性,我们不应该在HTML就将他们设置为全部大写,更好的解决方法是通过CSS来实现:</p> <p class="FocusMe"><img src="/static/imghw/default1.png" data-src="http://www.admin10000.com/UploadFiles/Document/201207/13/20120713140824730389.PNG" class="lazy" alt=""></p> <p class="FocusMe"><strong>  九、定义</strong></p> <p class="FocusMe">  大家平时制作web页面时不知道有没有碰到这样的问题,就是整站下来,使用了相同的布局和结构,换句话说,你在页面的布局上使用了相同的结构,相同的类名,但是突然你的上级主管说应客户的需求,有一个页面的布局需要边栏和主内容对换一下。此时你又不想为了改变一下布局而修改整个页面的结构,此时有一个很好的解决办法,就是在你的这个页面中的“</p> <p class="FocusMe"><img src="/static/imghw/default1.png" data-src="http://www.admin10000.com/UploadFiles/Document/201207/13/20120713140824585989.PNG" class="lazy" alt=""></p> <p class="FocusMe">  给“</p> <p class="FocusMe">  如果想了解更多这方面的知识,可以点击:</p> <ol class=" list-paddingleft-2"> <li><p><a href="http://css-tricks.com/id-your-body-for-greater-css-control-and-specificity/" target="_blank">ID Your Body For Greater CSS Control and Specificity</a></p></li> <li><p><a href="http://www.37signals.com/svn/archives2/case_study_reusing_styles_with_a_body_class.php" target="_blank">Case study: Re-using styles with a body class</a></p></li> </ol> <p class="FocusMe"><strong>  十、验证你的代码</strong></p> <p class="FocusMe">  人不免会出错,我们编写代码的时候也是一样的,你有时候总会小写或多写,比如说忘了关闭你的元素标签,不记得写上元素必须的属性,虽然有一些错误不会给你带来什么灾难性的后果,但也不免会给你带来你无法意估的错误。所以建议您写完代码的时候去验证你一下你的代码。验证后的代码总是比不验证的代码强:</p> <p class="FocusMe"><img src="/static/imghw/default1.png" data-src="http://www.admin10000.com/UploadFiles/Document/201207/13/20120713140824410337.PNG" class="lazy" alt=""></p> <p class="FocusMe">  为一有效的验证你的代码,我们可以使用相关的工具或者浏览器的插件来帮助我们完成。如果你的代码没有任何错误,W3C验证工具会在你们面前呈现绿色的文字,这样让你是无比的激动人心,因为再次证明了你写的代码经得起W3C的标准。</p> <p class="FocusMe">  如果想了解更多这方面的知识,可以点击:</p> <ol class=" list-paddingleft-2"> <li><p><a href="http://validator.w3.org/" target="_blank">The W3C Markup Validation Service</a></p></li> <li><p><a href="http://xhtml-css.com/" target="_blank">XHTML-CSS Validator</a></p></li> <li><p><a href="http://freesitevalidator.com/" target="_blank">Free Site Validator (checks entire site, not just one page)</a></p></li> </ol> <p class="FocusMe"><strong>  十一、逻辑顺序</strong></p> <p class="FocusMe">  这是一个很少见的错误情况,因为我想大家写页面都不会把逻辑顺序打乱,换句话说,如果可能的话,让你的网站具有一个先后逻辑顺序是最好的,比如说先写页头,在写页体,最后写页脚。当然有时也会碰到特殊情况,如何页脚部分在于我们代码的边栏以上,这可能是因为它最适合你的网站设计需求,这样或许是可以理解的,但是如果你有别的方式实现,我们都应该把页脚是放在一个页面的最后,然后在通过特定的技术让它达到你的设计需求:</p> <p class="FocusMe"><img src="/static/imghw/default1.png" data-src="http://www.admin10000.com/UploadFiles/Document/201207/13/20120713140824742405.PNG" class="lazy" alt=""></p> <p class="FocusMe">  上面我们一起讨论了多个如何让你开始写一个整洁的HTML代码。从一个项目的开始,这一切都是非常容易的,但是如果需要你去修复一个现有的代码,那多少都会有一定的难度。上面说这么多主要是告诉您将要如何学习编写一个良好的、整洁的HTML代码,并且一直坚持这样的编写。希望读完这篇文章后,在你的下一个项目中,能从头开始,坚持写一个整洁的HTML代码。</p> <p><br></p> <p>以上就是11个让你代码整洁的原则 - jerrylsxu的内容,更多相关内容请关注PHP中文网(www.php.cn)!</p> <p class="clear"><br></p>
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

<gum> : Bubble Gum Simulator Infinity- 로얄 키를 얻고 사용하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora : 마녀 트리의 속삭임 - Grappling Hook 잠금 해제 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Nordhold : Fusion System, 설명
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

HTML : 구조, CSS : 스타일, 자바 스크립트 : 동작 HTML : 구조, CSS : 스타일, 자바 스크립트 : 동작 Apr 18, 2025 am 12:09 AM

웹 개발에서 HTML, CSS 및 JavaScript의 역할은 다음과 같습니다. 1. HTML은 웹 페이지 구조를 정의하고, 2. CSS는 웹 페이지 스타일을 제어하고 3. JavaScript는 동적 동작을 추가합니다. 그들은 함께 현대 웹 사이트의 프레임 워크, 미학 및 상호 작용을 구축합니다.

HTML, CSS 및 JavaScript의 미래 : 웹 개발 동향 HTML, CSS 및 JavaScript의 미래 : 웹 개발 동향 Apr 19, 2025 am 12:02 AM

HTML의 미래 트렌드는 의미론 및 웹 구성 요소이며 CSS의 미래 트렌드는 CSS-In-JS 및 CSShoudini이며, JavaScript의 미래 트렌드는 WebAssembly 및 서버리스입니다. 1. HTML 시맨틱은 접근성과 SEO 효과를 향상시키고 웹 구성 요소는 개발 효율성을 향상 시키지만 브라우저 호환성에주의를 기울여야합니다. 2. CSS-in-JS는 스타일 관리 유연성을 향상 시키지만 파일 크기를 증가시킬 수 있습니다. CSShoudini는 CSS 렌더링의 직접 작동을 허용합니다. 3. Webosembly는 브라우저 애플리케이션 성능을 최적화하지만 가파른 학습 곡선을 가지고 있으며 서버리스는 개발을 단순화하지만 콜드 스타트 ​​문제의 최적화가 필요합니다.

HTML의 미래 : 웹 디자인의 진화 및 트렌드 HTML의 미래 : 웹 디자인의 진화 및 트렌드 Apr 17, 2025 am 12:12 AM

HTML의 미래는 무한한 가능성으로 가득합니다. 1) 새로운 기능과 표준에는 더 많은 의미 론적 태그와 WebComponents의 인기가 포함됩니다. 2) 웹 디자인 트렌드는 반응적이고 접근 가능한 디자인을 향해 계속 발전 할 것입니다. 3) 성능 최적화는 반응 형 이미지 로딩 및 게으른로드 기술을 통해 사용자 경험을 향상시킬 것입니다.

HTML vs. CSS vs. JavaScript : 비교 개요 HTML vs. CSS vs. JavaScript : 비교 개요 Apr 16, 2025 am 12:04 AM

웹 개발에서 HTML, CSS 및 JavaScript의 역할은 다음과 같습니다. HTML은 컨텐츠 구조를 담당하고 CSS는 스타일을 담당하며 JavaScript는 동적 동작을 담당합니다. 1. HTML은 태그를 통해 웹 페이지 구조와 컨텐츠를 정의하여 의미를 보장합니다. 2. CSS는 선택기와 속성을 통해 웹 페이지 스타일을 제어하여 아름답고 읽기 쉽게 만듭니다. 3. JavaScript는 스크립트를 통해 웹 페이지 동작을 제어하여 동적 및 대화식 기능을 달성합니다.

HTML : 웹 페이지 구조 구축 HTML : 웹 페이지 구조 구축 Apr 14, 2025 am 12:14 AM

HTML은 웹 페이지 구조를 구축하는 초석입니다. 1. HTML은 컨텐츠 구조와 의미론 및 사용 등을 정의합니다. 태그. 2. SEO 효과를 향상시키기 위해 시맨틱 마커 등을 제공합니다. 3. 태그를 통한 사용자 상호 작용을 실현하려면 형식 검증에주의를 기울이십시오. 4. 자바 스크립트와 결합하여 동적 효과를 달성하기 위해 고급 요소를 사용하십시오. 5. 일반적인 오류에는 탈수 된 레이블과 인용되지 않은 속성 값이 포함되며 검증 도구가 필요합니다. 6. 최적화 전략에는 HTTP 요청 감소, HTML 압축, 시맨틱 태그 사용 등이 포함됩니다.

HTML vs. CSS 및 JavaScript : 웹 기술 비교 HTML vs. CSS 및 JavaScript : 웹 기술 비교 Apr 23, 2025 am 12:05 AM

HTML, CSS 및 JavaScript는 최신 웹 페이지를 구축하기위한 핵심 기술입니다. 1. HTML 웹 페이지 구조를 정의합니다. 2. CSS는 웹 페이지의 모양을 담당합니다.

HTML : 프로그래밍 언어입니까 아니면 다른 것입니까? HTML : 프로그래밍 언어입니까 아니면 다른 것입니까? Apr 15, 2025 am 12:13 AM

Htmlisnotaprogramminglanguage; itisamarkuplanguage.1) htmlstructuresandformatswebcontentusingtags.2) itworksporstylingandjavaScriptOfforIncincivity, WebDevelopment 향상.

텍스트에서 웹 사이트로 : HTML의 힘 텍스트에서 웹 사이트로 : HTML의 힘 Apr 13, 2025 am 12:07 AM

HTML은 웹 페이지를 작성하는 데 사용되는 언어로, 태그 및 속성을 통해 웹 페이지 구조 및 컨텐츠를 정의합니다. 1) HTML과 같은 태그를 통해 문서 구조를 구성합니다. 2) 브라우저는 HTML을 구문 분석하여 DOM을 빌드하고 웹 페이지를 렌더링합니다. 3) 멀티미디어 기능을 향상시키는 HTML5의 새로운 기능. 4) 일반적인 오류에는 탈수 된 레이블과 인용되지 않은 속성 값이 포함됩니다. 5) 최적화 제안에는 시맨틱 태그 사용 및 파일 크기 감소가 포함됩니다.

See all articles