HTML的优化技巧
很多开发人员在提升Web页面性能的时候都是从多方面下手的,比如JavaScript、图像优化、服务器配置等,当HTML已经达到了一个瓶颈的时候,HTML页面的负载也是越来越负重,那么我们要如何有效的降低HTML 代码的复杂度和页面元素的数量呢?现在我们就去看看HTML的优化技巧。
在设计和开发过程中需要遵循以下原则:
- 结构分离:使用HTML 增加结构,而不是样式内容;
保持整洁:为工作流添加代码验证工具;使用工具或样式向导维护代码结构和格式
学习新语言:获取元素结构和语义标记。
确保可访问: 使用ARIA 属性和Fallback 属性等
测试: 使网站在多种设备中能够良好运行,可使用emulators和性能工具。
HTML,CSS 和JavaScript三者的关系
HTML 是用于调整页面结构和内容的标记语言。HTML 不能用于修饰样式内容,也不能在头标签中输入文本内容,使代码变得冗长和复杂,相反使用CSS 来修饰布局元素和外观比较合适。HTML元素默认的外观是由浏览器默认的样式表定义的,如在Chrome中h1标签元素会渲染成32px的Times 粗体。
三条通用设计规则:
- 使用HTML 来构造页面结构,CSS修饰页面呈现,JavaScript实现页面功能。CSS ZenGarden 很好地展示了行为分离。
如果能用CSS或JavaScript实现就少用HTML代码。
将CSS和JavaScript文件与HTML 分开存放。这可有助于缓存和调试。
文档结构方面也可以做优化,如下:
1、使用HTML5 文档类型,以下是空文件:
- >
- <html>
- <head>
- <title>Recipes: pestotitle>
- head>
- <body>
- <h1>Pestoh1>
- <p>Pesto is good!p>
- body>
- html>
2、在文档起始位置引用CSS文件,如下:
- <head>
- <title>My pesto recipetitle>
- <link rel="stylesheet" href="/css/global.css">
- <link rel="stylesheet" href="css/local.css">
- head>
使用这两种方法,浏览器会在解析HTML代码之前将CSS信息准备好。因此有助于提升页面加载性能。
在页面底部body结束标签之前输入JavaScript代码,这样有助于提升页面加载的速度,因为浏览器在解析JavaScript代码之前将页面加载完成,使用JavaScript会对页面元素产生积极的影响。
- <body>
- ...
- <script src="/js/global.js">
- <script src="js/local.js">
- body>
使用Defer和async属性,脚本元素具有async 属性无法保证会按顺序执行。
可在JavaScript代码中添加Handlers。千万别加到HTML内联代码中,比如下面的代码则容易导致错误且不易于维护:
index.html:
- <head>
- ...
- <script src="js/local.js">
- head>
- <body onload="init()">
- ...
- <button onclick="handleFoo()">Foobutton>
- ...
- body>
下面的写法比较好:
index.html:
- <head>
- ...
- head>
- <body>
- ...
- <button id="foo">Foobutton>
- ...
- <script src="js/local.js">
- body>
js/local.js:
- init();
- var fooButton =
- document.querySelector('#foo');
- fooButton.onclick = handleFoo();
验证
优化网页的一种方法就是浏览器可处理非法的HTML 代码。合法的HTML代码很容易调试,且占内存少,耗费资源少,易于解析和渲染运行起来更快。非法的HTML代码让实现响应式设计变得异常艰难。
当使用模板时,合法的HTML代码显得异常重要,经常会发生模板单独运行良好,当与其他模块集成时就报各种各样的错误,因此一定要保证HTML代码的质量,可采取以下措施:
- 在工作流中添加验证功能:使用验证插件如HTMLHint或SublineLinter帮助你检测代码错误。
使用HTML5文档类型
确保HTML的层次结构易于维护,要避免元素嵌套处于左开状态。
保证添加各元素的结束标签。
删除不必要的代码 ;没有必要为自关闭的元素添加结束标签;Boolean 属性不需要赋值,如果存在则为True;
代码格式
格式一致性使得HTML代码易于阅读,理解,优化,调试。
语义标记
语义指意义相关的事物,HTML 可从页面内容中看出语义:元素和属性的命名一定程度上表达了内容的角色和功能。HTML5 引入了新的语义元素,如