写点什么

不应忽视的 HTML 优化

  • 2010-05-13
  • 本文字数:1057 字

    阅读完需:约 3 分钟

随着 Web2.0 技术的不断发展,Web 前端的优化受到越来越多的关注,特别是 JavaScript 和 CSS 优化的讨论一直是热点,工具也相对丰富,而对 HTML 优化则有所忽视,最近,来自百度泛用户体验团队的工程师 Miller (chenminliang)撰文强调了HTML 优化的重要性和相关技巧。

Miller 首先举例说明了 HTML 优化稍显忽略的事实:

Steve Souders 的大作《 Even Faster Web Sites 》中谈到非常多有效的前端优化方法,例如 Javascript 的加载、CSS 选择符、图片优化、gzip、iframe 问题等,唯独没有细说 HTML 优化。

他强调 HTML 优化虽然看似微小,但是不可忽视:

在整个前端的构成中,HTML 是必不可少的一部分,而且是真正的展示“前端”。虽然与动辄十几 K 的 Javascript 相比,HTML 的大小在整个页面资源中一般不会占太多的比重,而且还有 Gzip,但是事实表明,大多数页面都有较大的压缩余地,即使是 Gzip 过后仍然能减小可观的体积…

Miller 在文中总结了 HTML 优化的各种方法,将其分为两类:绿色规则——在各类页面中适用且无害和橙色规则——在某些具体的情况下才适用或者有违标准。

绿色规则可以概括为以下几种:

  • 使用相对 URL,某些 href、src 属性如果与当前页面处于同一域名下,则使用相对 URL 能够节省至少一个域名的长度。
  • 删除 HTTP 或者 HTTPS,绝对 URL 都以 HTTP 或 HTTPS 等协议头开始,如果能确定 URL 的协议与当前页面 URL 的协议是一致的,或者说该 URL 在多种协议下均是可用的,则可以考虑删除这个协议头。
  • 删除注释,考虑不必要的 IE 条件注释和 CDATA 注释及自定义注释。
  • 压缩空白符,对于多数标签,可以通过删除多余的空白符来减少 HTML 体积,但是对于 pre 等是例外。
  • 压缩 inline css & Javascript,不管 inline 还是 external,都需要压缩,这是减小体积的最直接的方式。
  • CSS&Javascript 尽量外链,不仅可以减少体积,还能够充分利用浏览器的缓存机制。
  • 删除元素默认属性,在 HTML 规范中,很多 HTML 元素的属性是有默认值的,对于这些默认值可以抹去不写。

橙色规则就不一一列举了,感兴趣的读者可以直接查看原文

除了优化技巧之外,Miller 特别推荐了两款相关工具——Absolute HTML Compressor 和 PageSpeed1.6:

HTML 优化工具目前比较理想的是 Absolute HTML Compressor ,另外, PageSpeed1.6 中也引入了 HTML 压缩功能,不过目前只有四个简单的策略,尚处于实验性阶段。

随着 Web 前端性能受到越来越多的关注,包括 HTML 优化在内的各个领域将得到进一步的发展,并不断提高 Web 的用户体验,InfoQ 将继续关注和报道相关进展,感兴趣的读者可以查看富互联网(RIA)专题

2010-05-13 22:145112
用户头像

发布了 501 篇内容, 共 262.2 次阅读, 收获喜欢 61 次。

关注

评论

发布
暂无评论
发现更多内容

跨平台应用开发进阶(五) :uni-app 实现列表项左划操作

No Silver Bullet

uni-app 2月月更 左划删除

作业8

施正威

SSR 和前端编译,在这点上是一样的

CRMEB

一次历史漏洞分析与复现的全部过程

H

网络安全

书单

林逸民

学习 读书

模块八

Only

架构师实战营 「架构实战营」

【ELT.ZIP】OpenHarmony啃论文俱乐部——综述视角解读压缩编码

ELT.ZIP

鸿蒙 OpenHarmony 数据压缩

如何通过服务提升产品价值?

石云升

产品思维 体验设计 产品分析 2月月更 服务产品化

人大代表谈“元宇宙”:把握机遇,加速布局

CECBC

Pandas+Seaborn+Plotly:联手探索苹果AppStore

Peter

数据挖掘 数据分析 可视化 Kaggle

设计千万级学生管理系统的考试试卷存储方案

王大胖

人人皆可虚拟,直播还能这么玩?声网推出 MetaLive 元直播解决方案

声网

人工智能 音视频

攻克MySQL-索引基础

javaadu

MySQL 面试题 索引

过完年了, 为明年设计一个春联自动生成器, 给大家助助兴

DS小龙哥

2月月更

实践GoF的23种设计模式:SOLID原则

元闰子

设计模式 SOLID

NFT盲盒商城系统开发技术

薇電13242772558

NFT

mxGraph教程-开发入门指南

No Silver Bullet

流程图 2月月更 mxGraph

简谈什么是 Web 3.0

devpoint

元宇宙 Web3.0 2月月更

迭代器总结

编程三昧

JavaScript 前端 迭代器 2月月更

模块八

撿破爛ぃ

架构训练营

国内外好用的OKR管理工具有哪些?

爱吃小舅的鱼

Go 语言入门很简单:Go 反射

宇宙之一粟

一个简单的方法排列任务优先级

Bruce Talk

互联网产品管理课-笔记(16/100)

hackstoic

产品

精选22个pandas实用函数

Peter

Python 数据分析 pandas

【Python】这个列表TTT熟悉

謓泽

Python 2月月更

从俄乌战争看区块链技术在未来国防领域的应用

CECBC

一次TDD(Test Driven Development)尝试感受

Bruce Talk

技术 敏捷 TDD Agile

【干货】Servlet内存马加载流程分析

网络安全学海

黑客 网络安全 信息安全 渗透测试 安全漏洞

能源产业数字化转型:区块链如何“炼”?

CECBC

攻克MySQL—索引优化

javaadu

MySQL 面试题 索引

不应忽视的HTML优化_Java_崔康_InfoQ精选文章