如何打造一个全满分网站

标签: gtmetrix yslow lighthouse pwa | 发表时间:2017-11-05 15:03 | 作者:张京
出处:https://segmentfault.com/blogs

作为一个全栈互联网工程师,我们的目标决不仅仅满足于功能的实现,而且要包括性能、安全、易用性等等各方面的考量。那么是否有一些可以公开评测的标准,使我们能够准确地知道目前我们网站的质量水平在全行业中处于什么样的水平呢?随着技术水平的不断进步,网站评测方面的各种工具也在不断演进。

工具

工欲善其事,必先利其器。

想要知道自己网站的质量水平,凭想像和猜测是不行的,必须要有可以客观衡量的工具。

YSlow

最早做这方面尝试的是2012年诞生于 YahooYSlow,但是现在已经逐渐淡出历史舞台。它的名称实际上是英文 Why Show(为什么这么慢?)的缩写,从它的名字你应该能知道它是帮助站长解决网页加载速度的工具。 YSlow是一款浏览器插件,可以支持包括 Chrome, Firefox, Safari等等主流浏览器。在浏览器上安装相应插件后,就可以对任意网站进行评测,最后给出一个总体评分。评测内容包括网页是否包含了过多的 HTTP请求, JSCSS是否经过压缩,是否采用 CDN等等,主要是提供给站长一个优化的方向和参考建议。

图片描述

PageSpeed

YSlow之后, Google推出了自己的网页优化建议工具 PageSpeed Insights,这是一个网页工具,你不需要像 YSlow一样下载插件和安装,你只需要打开它的网页,输入任何你想测评的网址,就可以得到优化建议了。

图片描述

GTmetrix

我最常使用的工具不是以上两款,而是一个名叫 GTmetrix的网站,这个网站结合了以上两个工具,给出了更加完整的建议。

图片描述

Lighthouse

更强大而严格的工具还是 Google推出的 Lighthouse。这也是一款浏览器插件,不过目前只能用于 Google自家的 Chrome浏览器。它从4个方面对任何网站进行评测,包括性能、易用性、最佳实践。我们下面将重点介绍如何能在这4个方面都完全满足 Google的要求。

图片描述

优化

GTMetrix

优化的第一步,我们还是先从 GTMetrix开始。一般网站常见的问题和建议如下:

CDN

通常情况下,你需要为你的网站开通 CDN服务,以确保在地理位置上离用户最近的服务器可以优先为用户提供服务。提供 CDN服务的厂商很多,而且价格并不昂贵,很多云服务商比如 阿里云百度云都有提供这方面的服务。

Enable gzip compression

这一项主要是检查你的 nginx服务器是否设置了 gzip压缩传输的方式。打开你的 Chrome开发者工具,检查 Network标签里每一个请求的 Response header,看一下是否有 content-encoding: gzip,如果没有,说明你的网站没有设置gzip传输。

图片描述

解决方案:参照我的这篇文章 《我的nginx锅炉片》设置。

Add Expires headers

这一项也是很多网站缺失的配置,由于没有给 jpg图片以及 cssjs设置合适的过期时间,导致每次访问网站都需要重新从网站读取内容,这是很多网站访问速度慢的原因。设置方式:同样,参照上一节所提到的文章。

解决方案:参照我的这篇文章 《我的nginx锅炉片》设置。

图片大小

很多情况下,或者是出于无知,或者是出于偷懒,工程师们倾向于把一张大图用 css方式缩小,例如这样: width: 100px; height: 50px;。导致的结果是这张图片在网页上看起来似乎图片缩小了,但实际上文件尺寸并没有变小。这也是很多网站变慢的主因。

解决方法:参照我的这篇文章 《用imgproxy自动缩放图片》设置。

雪碧图

如果你的页面中有很多小图标的时候,最糟糕的作法莫过于把它们全部切成小碎的 jpg或者 png,这样会使你的页面在加载时向服务器端发送很多次 http请求,而每一次请求都有独立的建立连接、传输数据、断开连接的过程,非常浪费资源。

解决方案:如果可能的话, 把这些图标做成独立的图标字体文件。如果不行,则 把它们压缩成雪碧图

压缩js和css

通常情况下,你刚刚写完的 js是下图中左边这种样子的,而通常大公司网站的代码是图中右边这样的。

clipboard.png

左边的代码人类阅读没有什么问题,但是你不应该把它们就这样在网络中传输。第一,浪费流量;第二,你能读得懂,你的友商也能读得懂,不利于安全。

解决方案:你应该把你的js/css/html进行 丑化(uglify)和压缩(minify)

终极大法

以上所有这些修改建议听上去都不错,但是我要一个一个做下来太繁琐怎么办?也许你应该考虑用一个现代的框架帮你自动完成这些事情,比如 Angular/React/Vue,或者你自己全用 Grunt/Gulp/Webpack完成所有这些事情。你知道这就是为什么前端工程师要学习框架的原因了吧?因为我的博客网站是全用 Jekyll直接建在 Github Pages上的,使用了 CloudFlareCDN,而它们已经自动帮我完成了所有这些烦琐的事情,所以起点比较高,很轻松就能在 GTMetrix上得到99分的高分。

Lighthouse

在完成了 GTMetrix的要求,能够获得 99分以上的高分之后,我们还想要达到更高的标准,挑战 GoogleLighthouse满分!

Lighthouse从以下4个方面对网页做出评价,我们逐个来谈。

渐进式Web应用(Progressive Web Apps)

头一项标准 『渐进式Web应用』,这个标准是 Google自家发明的。其目的是为了让网站能在网络不畅通的情况下也能显示基本内容,或者上一次缓存的内容,而不是给出一个难看的『网络不通』的提示,并且能够让用户像安装普通应用一样直接把网页安装在手机上。PWA的终极理想是可以用网页应用来取代应用,所以目前并不被 Apple支持。 Google官网给出了关于如何实现 PWA的详细指南,按照指南学习一步一步就可以构建出你的第一个 PWA网页。建设完成后可以用 Lighthouse来测试一下你的网页到底有多符合 PWA标准。

渐进式Web应用标准共有11项。

下面重点介绍一下为了使一个网页能满足基本的 PWA要求所必须要完成的工作:

manifest.json

首先,你的网站必须要有一个 manifest.json文件,这个文件里描述了最基本的一些信息。比如我的网站的 manifest.json文件是这样的:

  {
  "name": "日新亭",
  "short_name": "日新亭",
  "description": "苟日新,日日新,又日新",
  "start_url": "/index.html",
  "orientation": "any",
  "icons": [{
    "src": "/assets/img/icons/android-chrome-512x512.png",
    "sizes": "512x512",
    "type": "image/png"
  }, {
    "src": "/assets/img/icons/android-chrome-192x192.png",
    "sizes": "192x192",
    "type": "image/png"
  }],
  "theme_color": "#000000",
  "background_color": "#000000",
  "display": "standalone"
}

这里要注意的是你必须事先准备好你的网站的 Logo图标,而且尺寸必须是 512x512的。另外,这里设定的主题颜色必须和页面中的颜色相一致。在各页面的头部需要添加以下代码行:

      <!-- Favicon -->
    <link rel="icon" type="image/png" href="/assets/img/icons/favicon-16x16.png" sizes="16x16">
    <link rel="icon" type="image/png" href="/assets/img/icons/favicon-32x32.png" sizes="32x32">
    <link rel="icon" type="image/png" href="/assets/img/icons/favicon-96x96.png" sizes="96x96">

    <!-- Apple Touch Icons -->
    <link rel="apple-touch-icon" href="/assets/img/icons/apple-touch-icon.png" />

    <link rel="manifest" href="/manifest.json">

    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-title" content="{{ site.title }}">

    <!-- Android Lolipop Theme Color -->
    <meta name="theme-color" content="{{ page.color }}">

在这里指定了你的网站的 manifest.json文件的路径,并且指定了页面的 theme-color主题色。

serviceworker.js

在你的主页面当中增加以下代码用来判断浏览器是否支持 ServiceWorker,如果支持的话,加载 ServiceWorker文件:

    if ('serviceWorker' in navigator) {
    navigator.serviceWorker.register('/service-worker.js');
  };

然后在根目录下增加一个 serviceworker.js的文件:

  var cacheName = 'fengerzh';
var filesToCache = [
  '/',
  '/index.html',
  '/assets/js/main.js',
  '/assets/css/main.css',
  '/assets/img/placeholder.png',
  '/assets/img/icons/preloader.svg',
  '/assets/img/icons/read.svg',
];

self.addEventListener('install', function(e) {
  e.waitUntil(
    caches.open(cacheName).then(function(cache) {
      return cache.addAll(filesToCache);
    })
  );
});

self.addEventListener('activate', function(e) {
  e.waitUntil(
    caches.keys().then(function(keyList) {
      return Promise.all(keyList.map(function(key) {
        if (key !== cacheName) {
          return caches.delete(key);
        }
      }));
    })
  );
  return self.clients.claim();
});

self.addEventListener('fetch', function(e) {
  e.respondWith(
    caches.match(e.request).then(function(response) {
      return response || fetch(e.request);
    })
  );
});

把指定的文件保存在缓存中,这样下次如果网络不通的话,浏览器会从缓存中取文件,而不会出现网络不通的画面。建好了 ServiceWorker文件的页面,会在 Chrome工具栏里看到这样的效果:

clipboard.png

同时,完成了 PWA效果的网站,可以让用户在手机中直接安装,比如:

图片描述

然后,就会在用户的主屏幕上生成一个带有你设定的图标的应用:

图片描述

点击图标打开应用,会来到一个没有任何URL地址栏和工具栏的页面,使用户完全感觉不到是在浏览网页:

图片描述

性能

Lighthouse对性能的要求基本和 GTMetrix差不多,如果你能在 GTMetrix获得高分的话,通过 Lighthouse的这一项测试应该不难。唯一多要求的一项是所有图片都要求是 webp格式,但是 Safari浏览器目前并不支持这种格式,所以如果你把网站上的所有 jpg文件改成 webp文件的话会导致你的网站里的图片在 iPhone上不能显示。(我目前的网站全面采用了 webp格式,不过会在不久的将来全面切换回 jpg,主要原因是iPhone目前还不兼容。)

性能标准共有10项。

可用性

可用性标准主要是指在制作网页时必须考虑残疾人的需求。

可用性标准共有8项。

Elements Use Attributes Correctly

这一项标准的要求之一是:所有图片必须有 alt属性,这样如果图片不能显示时,也能出现合适的文字。当然还有很多其它要求,你可以根据 Lighthouse给出的建议逐项调整。

Elements Describe Contents Well

这一项标准的要求之一是:所有 input输入框必须有 label或者 aria-label。如下面这样:

  <input type="text" class="search-field" placeholder="搜索" aria-label="搜索">

Color Contrast Is Satisfactory

这一项标准的要求是所有字体的前景色和背景色的对比度需要足够强,以便于视力不好的人士能够分辨页面上的字迹。如果你不知道某两种颜色的对比度是否足够,可以用 这个网页检测,绿色的Pass表示合格。

clipboard.png

有时候这一标准会有误判,为了能让它通过,你可能需要设置额外的 background-color属性,例如( stylus):

          p
            margin 0 0 rem(30px)
            background-color #141414
            color darken(lightGray, 20%)
            font-size rem(17px)
            line-height rem(26px)

最佳实践

最佳实践标准是指一个理想网站所应该达到的最高标准。包括:避免使用 Application Cache,避免使用 WebSQL,使用 Http 2.0,使用 https,避免使用 document.write,避免使用 console.log等等。这些标准看上去很琐碎,但是每一项标准的提出都有其合理性,应当竭尽全力遵守。

最佳实践标准共有15项。

使用http 2.0

关于如何开通 http 2.0,可以参考我之前写过的一篇文章《 免费给你的网站加上蓝色小闪电》。

成果

如果你完成了以上的所有优化步骤,相信你的网站应该可以得到一个比较高的评分了。现在我们随便找个网站评测一下看看吧,别人家的网站效果大抵都是这样的:

clipboard.png

而我们的网站,经过调校之后的效果是这样的:

图片描述

是不是很有成就感呢?


以上所有代码都可以在我的 开源博客模板代码库中找到,供大家学习参考,不吝啬的请大家给个星星吧!

相关 [网站] 推荐:

网站推荐:IFTTT(if this then that)

- 小皮球香蕉梨 - 有意思吧
这是一个神奇的网站,比某电视上天天放的那个广告要神奇许多. 就像它的域名 ifttt.com 一样,虽然丑却十分个性. 昨天晚上,ifttt.com 在 Twitter 被瞬间引爆,每个被邀请的人都会再拥有5个邀请名额,源源不断的邀请让 Geek 很兴奋. 那么,ifttt 到底是什么呢. 这是一个条件触发网站,当 A 条件触发时,自动激发 B 条件发生.

Facebook 网站架构

- - idea's blog
我收集到一些文章和视频, 可以带你窥探 Facebook 的架构. Facebook 承载了几十亿的用户, 它的架构(包括思想和实现)是非常值得参考的. 当然, 你要小心不要照搬 Facebook 的每一字一句, 因为任何思想和实现都是有自己的应用场景的.. Google Talk 界面开发分析. 使用Python POST任意的HTTP数据以及使用Cookie.

用BrowserID注册网站

- ashuai - Solidot
Mozilla宣布了一个实验项目BrowserID,提供了一种注册网站的新方法. 注册网站通常的方法是电子邮件验证,造成用户时间的浪费,要求用户登录另一个网站,记住另一个密码. BrowserID(源代码发布在github上)提供了一种更简单的方法,消除了电子邮件验证. 它是Verified Email Protocol实现,基于公钥系统和Mozilla的认证服务器,以确保用户身份的真实性.

ifttt、GGG与网站图谱

- babyone - cnBeta全文版
尽管伯纳斯・李(Tim Berners-Lee)在发明WWW之初,心中就有一个GGG(Giant Global Graph)的宏大梦想,但是直到Google的网页图谱、尤其是Facebook的社交图谱、Twitter的兴趣图谱之后,人们才真正意识到图谱的网络效应魔力. 不过这仍然未及伯纳斯・李的预期,他理想中的GGG是一张数据的图谱、服务的图谱,而不仅仅是网页、人或兴趣.

苹果网站的特点

- fei - 所有文章 - UCD大社区
以前听同行讲过一次apple.com,在他眼里apple.com就是丰碑,基本没有不好. 任何哲学的理论和术语都可以往它身上套,简直就是成就与完美的化身. 这问题我觉得需要拆解分层次的看,任何有特点的设计必然有其优势,也有其局限性. 我认为讲apple.com很有特点可能更合适,因为“特点”只是个中性词.

中国的大网站

- yangzhe - Jarain
//别的搜索引擎把不能搜的挑出来屏蔽,百度把能搜的挑出来让大家搜. //以Twitter为指导思想,以饭否和叽歪的关站为经验教训,以稳定压倒一切为基本原则的具有中国特色的社会主义微博. //什么博客什么校友录什么白社会什么搜狐微博都是浮云. //中国只有两个有态度的网络媒体,一个是人民网,一个是网易.

苹果网站的特点

- 图腾 - 千鳥志
以前听同行讲过一次apple.com,在他眼里apple.com就是丰碑,基本没有不好. 任何哲学的理论和术语都可以往它身上套,简直就是成就与完美的化身. 这问题我觉得需要拆解分层次的看,任何有特.

50个黄色网站

- 小汐 - 帕兰映像
一个好的黄色网站的重点并不是够不够黄,也不一定要黄色电影、黄色视频、黄色图片和黄色小说一应俱全,而是要黄的有质感有层次,欣赏起来要赏心悦目. 在浩瀚的互联网宇宙中,有无数的黄色网站. 有的你可能已经深入接触,有的你可能从未体验. 本文里面,帕兰将向你推荐50个来自不同国家的优质的黄色网站,请准备好大饱眼福.

团购网站会死么?

- 子龙 - Tech2IPO
现在讨论这个问题有人会觉得很可笑,认为答案无可争议. 但是只要有人气聚集的地方就需要团购,除非团购有一天提供的东西不符合团购的“惊喜”,或是不足以吸引用户强烈的购买欲望. 对于团购用户来说,“惊喜”之一来自于价格;“惊喜”之二来自于“适时冲动消费”,冲动的前提是“价格”,其次是当时或是短期内有需要的产品;“惊喜”之三是身边的”商家+服务组合”—-不仅仅是价格,贴心的服务组合特别是餐饮的套餐组合推荐而不需要客人单点更符合大众的消费习惯.

一些IP查询网站

- 19GHz - iGFW
一些境内服务器的IP查询网站:. 一些境外服务器的IP查询网站:. https://whoer.net/ (支持https). 各网站查询到的IP归属地可能有差异,以apnic.net为准. 本文原始地址:http://igfw.tk/archives/5611.