提高页面速度的10种基础方法

什么是Page Speed

Page Speed是将内容完全加载到网页上所花费的时间。

对于任何给定的用户来说,页面缓慢的原因可能有很多,你的用户可能正在火车上,通过信号弱的隧道,或者他们的互联网速度很慢。

通过遵循最佳实践,我们至少可以通过确保我们已经做了最好的工作来缓解问题。

现在你知道它是什么了,下面我就来教你如何提高页面速度。

注意:这些是按难度顺序列出的。在某个时候,你将需要开发人员来帮助优化你的网站。

 

1.使用CDN

CDN是内容传输网络的缩写。使用CDN可以让你有效地访问全球数百台小服务器,这些服务器为你提供网站的副本,大大减少了你的网站获取时间。如果你没有使用CDN,你的网站的每一个请求(包括图片、css和JavaScript)都会被缓慢地传送到你的服务器上。

根据HTTPArchive中的4.68亿个请求,48%的请求不是来自CDN。那是超过2.24亿的请求,如果他们花几分钟的时间给自己的网站添加一个CDN,速度可能会超过50%。

一定要检查你的CDN配置是否正确——在你的CDN中缓存丢失意味着CDN必须向你的源服务器请求资源,这就违背了使用CDN的初衷!所以,你的CDN必须要有一个正确的配置。

2.启用GZIP压缩

在一些CDN上,GZIP压缩只是一个标有 "启用压缩 "的复选框。这大概会减少一半的文件大小,你的用户需要下载文件才能使用你的网站,你的用户会因此而喜欢你。

 

3.使用较小的图像

这意味着既要降低分辨率(例如,摄像头的输出从4000x3000像素减少到网络的1000x750),又要通过压缩文件来减小尺寸。

如果你的网站使用WordPress,则有一些插件会在你上传图片时自动为你执行此操作。

在撰写博客文章时,我个人使用TinyJPG压缩图像。

 

4.减少页面发出的请求数

目标是减少加载页面顶部部分所需的请求数量。

这里有两种思维方式,你可以:

  • 通过删除花哨的动画或不能改善网站体验的图像,减少整个页面上的请求数量。
  • 或者,你可以通过使用延迟加载来推迟优先级不高的加载内容。

 

5.尽可能避免重定向

重定向会大大降低网站速度。使用响应式css并从一个域为你的网站提供服务,而不是为移动用户提供特殊的子域。

有些重定向是不可避免的,比如 www-> 根域 或 根域 ->www,但你的大部分流量不应该经历重定向来查看你的网站。

 

6.减少到第一个字节的时间

到第一个字节的时间是指你的浏览器在发出资源请求后,从服务器接收到第一个字节的数据所花费的时间。

有两个部分:

  • 在服务器上花费的时间
  • 发送数据所花费的时间

你可以通过优化你的服务器端渲染、数据库查询、API调用、负载平衡、你的应用程序的实际代码以及服务器的负载本身(特别是如果你使用的是廉价的虚拟主机——这将影响你的网站的性能),来改善你在服务器上花费的时间。

你可以使用CDN大大减少发送数据所花费的时间。

http://www.ssnd.com.cn 化妆品OEM代加工

7.减少并删除阻止渲染的JavaScript

外部脚本(特别是那些用于营销的外部脚本)往往会写得很差,会阻止你的页面加载,直到它运行完毕。

你可以通过将外部脚本标记为异步来减少这种影响:

<script async src="https://example.com/external.js"></script>

你还可以延迟加载市场营销脚本,直到用户开始滚动为止:

window.addEventListener(
  'scroll',
  () =>
    setTimeout(() => {
      // 在此插入营销片段
    }, 1000),
  { once: true }
);

 

8.缩小CSS和js

Minifying是指使用工具来删除空格、换行符和缩短变量名。通常情况下,这将作为构建过程的一部分自动完成。

要缩小JavaScript,请查看UglifyJS。

要缩小CSS,请查看cssnano。

 

9.删除未使用的CSS

自Chrome 59(2017年4月发布)以来,在Chrome DevTools中可以看到未使用的JS和CSS。

要看这个,打开DevTools,显示控制台抽屉(就是点击Esc时出现的那个烦人的东西),点击左下角的三个小点,打开 "Coverage",就可以看到。

点击带有重新加载图标的按钮将刷新页面,并审核CSS和JS的使用情况。

 

10.定期跟踪网站速度

在你的网站速度变慢的瞬间,修复网站速度问题就会容易得多。除此之外,如果你把检查网站速度作为一种习惯,那么修复网站速度慢的问题就会变成一件小得多的事情。

上一篇:B站崩了,如何防止类似事故的出现?


下一篇:有CDN的情况下,查找服务器的真实ip