前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >怎样简单的提高网站性能

怎样简单的提高网站性能

作者头像
javascript.shop
发布于 2019-09-04 09:42:32
发布于 2019-09-04 09:42:32
2.6K0
举报
文章被收录于专栏:杰的记事本杰的记事本

小小性能改变,大大影响发生

用户的耐心不是线性的。第1秒的时候基本上没有人会放弃这个站点。但是,1秒开外之后,如果没有适当的反馈的话(例如浏览器标头显示页面标题),用户开始以一个加速的比率离开。到3~4秒的时候,一般的站点会一半的潜在用户。当然,具体的阈值根据网站、用户行为和意图以及其他因素不同而有所不同……但万变不离其宗。

瓶颈

快速测试:当HTML载入浏览器之后,用户等待你页面加载的时间百分比是多少?如果你不是做web开发的,或是经常混迹于性能社区的话答案可能会让你大跌眼镜。一般超过90%,用户花在等待上的时间的90%实在页面HTML载入到浏览器之后。为什么会这样呢?

获取HTML仅仅是个开始

大肆分析浏览器是如何工作有点超出范围了,不过总的来说,浏览器解析HTML是有序地发现的资源(如脚本,样式和图片)、请求,然后要么解析,要么执行或者就是适时显示。

但是这些资源并不是一次性获取的。相反,浏览器通过页面只能向服务器打开有限数量的连接,通过建立TCP和HTTP连接和一些不可避免的延迟,发送的请求和响应的字节通过网络传回来。

因此,一般而言,浏览器和服务器之间的双向运输的代价是昂贵的。HTML的结果标记,资源的数目和顺序是性能上绝对关键的因素。

在我们关心假期网站访问量之前,我们花个几分钟看看web开发者和网站站长关于网站性能所犯的7大错误,以及如何避免和纠正的一些建议。

1. 太多的HTTP请求

这是绝对多数网页性能问题的症结所在,许多有效的解决该问题的WPO技术是完全不同的方法,下面就是一些:

合并脚本和样式简单地将脚本文件们合并成一个。对于样式,可以直接把所有.css文件合并成一个。人工维护需要很大成本,但目前有自动化的解决方案。

合并图片为SpritesCSS Spriting已经变成主流技术。其做法是将很多个公共图片合并为一个大的图片文件,然后你通过CSS控制位置让图片需要的地方显示。于是,告别N多图片,现在只有一个。

事先提醒一句,这个技术的维护是很折腾的,因为即使是个很小的更改也要更新整个图片以及CSS,甚至是HTML。幸运的是,CSS spriting自动化工具如SpriteMeCompassYottaa

使用尽量少的图片在一个页面上行使用太多图片是个老大难问题了,其历史可以追溯到古老的img标签。一般有两类解决方法。其一是使用CSS代替图片文件(background-color, border, buttons, hover效果等),另外则是对小图使用”data URIs

当图片对于页面是必需的情况下我们可以考虑图像的分页,例如电子商务的目录。

另外的解决方法可能就有些强硬了:就是让设计师或是产品所有者创建简单的不需要很多图片的页面。

2. 客户端最低限度处理

很多站点不能很好地运用客户端的能力,而把所有的工作都交给服务器。举个简单的例子,如表单验证:把表单数据发送给服务器,在服务器端验证,然后返回错误信息。oh, my GAGA, 这可不是一般的低效啊。

客户端的验证相反,验证用户输入的信息应该在页面内,就在输入发生的地方。由于安全的原因,网页应用程序也应该在服务器端验证。web安全准则之一即是不能相信用户的输入。所以,客户端的验证是出于性能和交互的原因,而服务器端的验证是出于安全原因。

使用网络标准和MVC分离使用web标准对于创建易维护,可访问,易证明的站点是很关键的。其也性能最佳化最好的基础。使用现代网络标准鼓励内容(HTML),样式(CSS)和行为(JavaScript)分离。

换句话说,历史悠久的"MVC"[[Model/View/Controller]设计模式正在你的网站代码中发挥着作用。

把HTML(实为DOM)当作module,CSS作为view,JavaScript作为controller。这种分离会使代码更高效,更利于维护,也使得很多优化技术的应用更为可行。

演示代码放到客户端上面提到的表单验证的例子,很多场景要求客户端做的更多。图表和形状——任何形式耐看的可视化数据——曾经必须依靠服务器端。

黄鹤一去不复返。现在它就是把数据从服务器端推送到客户端(例如JSON格式),然后使用CSS和JavaScript在浏览器中创建漂亮的图形,图表,可视化内容。这种方法避免了很多与服务器的交互,可以说,服务器做了更有意义的事情。

因为仅仅是推送数据,因此,节约了服务器的CPU,缩短了等待时间,并利用未充分利用的资源提供给每个客户端。有不少很赞的工具可以数据的可视化处理,包括:ProcessingD3 和  Flot

利用Ajax技术只让页面需要的一小部分去响应用户的操作,可以让你的网站或web程序变得更加的互动和高效。这有多种方法(例如获取HTML或脚本或数据)。如果你不需要的话,你可以不要刷新整个页面!如果你还未加入Ajax的大家庭,这本书虽然有些年头了但是概述是相当棒的!

3. 低并行请求数

获取一个脚本,然后解析它,执行它,再获取下一个,如此往复。然后使用所有可用的链接,从同一个服务器下载一些图片。它们一旦下载完毕,然后获取其他。听上去有效?事实并非如此。用户的带宽往往不是限制的主要因素,相反,是没有考虑到浏览器的行为低效的标记。

你可以通过一些举措让所有浏览器一次可以发出更多的请求,这对于延迟很有效果。

使用浏览器相应域分区一些老的单依旧流行的浏览器,如IE7,有个称为“域分区”的东西。具体来讲就是使用指向同一服务器但不同的域名来提高每次页面的请求数目。例如img1.foo.comimg2.foo.com要比单纯使用img.foo.com两倍高效下载。注意,对于新兴浏览器,这个技术不适合,因为你需要承担DNS成本而实际并未带来什么好处。WPO大师Steve Souders对这个权衡做了很好的解释工作,点击这里

使用智能脚本加载现在的脚本下载器激增,这些可以最优化多个脚本下载的性能。这些脚本下载器通常都是采用异步下载,避免默认的脚本阻塞等问题。关于脚本下载,可以多多参考《高性能网站进阶指南》一书,这里不多啰嗦。

4. 没有使用浏览器缓存或本地存储

显然,最快的获取资源的方法就是从本地缓存中获取了。

使用正确的header为静态资源设置长时间缓存头,尤其是这些资源被多个页面调用的时候,这是一个很好的提高性能的方法。因为明确的客户端缓存失效是不可能的,更新缓存内容的方法一般是对其名字进行处理。

还有另外一种技术,如果你手动做的话代价较高,如果自动化(例如通过脚本构建)就很迅速。这个方法就是使用"Expires"头。由于经常更新内容,使用"Last-Modified"响应头,以便在浏览器中触发条件"If-Modified-Since"请求。条件请求要明显慢于本地缓存查找,但远远高于一个完整的返回。

这儿有个相当不错的HTTP缓存综述

使用本地存储(local storage)一个WPO新利器就是HTML5中的local storage。对于支持的浏览器,其存储要比cookie精确很多很多,而且跟cookie相比,其请求无压力。

5. 第三方插件

第三方组件很多时候就是网页性能祸根。

避免第三方插件必要的插件有时候还是需要的,但是,为了避免最后搞得像瘟疫一样,避免使用之。

使用异步实现对于尝试使用的插件,最好采用异步实现。以避免其糟糕的性能拖累你整个页面的交互体验。

性能测量(停止使用低性能的)如题。

6. 太多的字节数

有不少方法可以让响应的尺寸更小。

压缩一个很明显也很重要的方案就是引入压缩(gzip)。客户端轻微的解压性能损失通常通过较少延迟,和较少字节缓解。在服务器端,预压缩静态资源有助于较小CPU的开销。像Apache的mod_deflate中的服务器端解决方案,压缩动态内容,以确保压缩的内容发送到客户端并可以处理它(像请求头表示的"Accept - Encoding:GZIP, DEFLATE")。

需要注意的是和缓存相结合的压缩。确保使用"Vary: Accept-Encoding"头,以便缓存可以响应合适的请求内容。

其他技术包括:

  • 更彻底的内容编辑
  • 图像优化(http://www.smushit.com/ysmush.it/)
  • JavaScript和CSS重构和最小化
  • 客户端代码重用
  • 分页
  • Ajax
  • cookie的域(图片等静态资源)

7. 未使用全球网络

另一个常见错误就是忽略地理位置。如果您的网站是在纽约市的数据中心托管,在加利福尼亚州的用户和波士顿的用户(更不用说亚洲)有一个巨大差异的延迟。传统DNS服务内容扮演的是边缘角色。使用云服务提供商发布内容至更多的地点,使用户总是从他们附近的服务器获取,这比DNS更好。

像Yottaa尖端的网络性能优化服务,可以跨多个云服务提供商的路由请求您的网页,其内容分发到世界各地的用户,代表了不同地域用户优化的下一代解决方案。

性能问题,特别是在假期前后。在黑色星期五,网络星期一之前,衡量你的网站的性能,然后改进它。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2012年4月11日2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
web前端性能优化
网站的划分一般为二:前端和后台。我们可以理解成后台是用来实现网站的功能的,比如:实现用户注册,用户能够为文章发表评论等等。而前端呢?其实应该是属于功能的表现。并且影响用户访问体验的绝大部分来自前端页面。
lyb-geek
2018/08/16
1.4K0
web前端性能优化
32. 网站性能介绍
网站性能对于普通用户来说,最直接的体现就是响应时间。用户在浏览器上直观感受到的网站响应速度,即从客户端发送请求,到服务器返回响应内容的时间。
Devops海洋的渔夫
2022/01/17
4830
32. 网站性能介绍
《高性能网站建设指南》读书笔记
这本书是很久之前买的,今天回顾了一下,顺便记录一下笔记。 本书的副标题是“前端工程师技能精髓”可见这本书的牛逼之处。这本书也很薄,只有147页,但是每一章都是精髓。由于这本书每章提出了一个性能优化的方法,我们也就按照每张的具体内容给出吧。
kai666666
2020/10/17
3920
前端开发总结:如何优化网站性能?
学前端这么久了,从一无所知到web网页的开发,自己也是踩了巨多的坑,自己也在不断的摸索中,短时间内可能不会再做前端了,毕竟java是我的主方向。总结一下web网站在性能提升方面前端能做些什么优化,其中有结合一些资料,也有自己的经验之谈,毕竟不是专门学前端的,有不对的地方敬请多多指教。
beifengtz
2019/06/03
1.1K0
Web 前端性能优化准则
“只有10%-20%的最终用户响应时间花在接收请求的HTML文档上,剩下的80%-90%时间花在HTML文档所引用的所有组件(图片,script,css,flash等等)进行的HTTP请求上”
书童小二
2018/09/03
1.1K0
Web 前端性能优化准则
快速定位网站性能问题,提前下班!
直接来一张大图你怕不怕?哈哈 咱们先看看谷歌浏览器network中waterfall各字段的含义哈。简单看下就成,用到了再查不耽误的。
用户8200753
2023/10/22
2850
网站优化 14条–雅虎十四条优化原则[通俗易懂]
大家好,又见面了,我是全栈君。相信互联网已经越来越成为人们生活中不可或缺的一部分。Ajax,flex等等富客户端的应用使得人们越加“幸福”地体验着许多原先只能在C/S实 现的功 能。比如Google机会已经把最基本的office应用都搬到了互联网上。当然便利的同时毫无疑问的也使页面的速度越来越慢。自己是做前端开发的,在性能方面,根据Yahoo的调查,后台只占5%,而前端高达95%之多,其中有88%的东西是可以优化的。
全栈程序员站长
2022/07/19
5250
Web性能优化之雅虎军规
相信互联网已经越来越成为人们生活中不可或缺的一部分。Ajax,flex等等富客户端的应用使得人们越加“幸福”地体验着许多原先只能在C/S实 现的功能。 比如Google机会已经把最基本的office应
郑小超.
2018/01/24
1.2K0
网站性能优化
  终端用户响应的时间中,有80%用于下载各项内容。这部分时间包括下载页面中的图像、样式表、脚本、Flash等。通过减少页面中的元素可以减少HTTP请求的次数。这是提高网页速度的关键步骤。   减少页面组件的方法其实就是简化页面设计。
超然
2018/08/03
3.3K1
Web 前端性能优化 : 如何有效提升静态文件的加载速度
本文主要讲述了如何通过Webpack2+ES6+Babel来对前端代码进行构建,从而提升代码的性能和兼容性。主要包括了代码压缩、文件合并、静态资源缓存、代码分离、开启浏览器缓存、使用CDN、代码混淆、图片懒加载、使用Tree shaking、代码调试和性能优化等。同时介绍了Webpack2的Tree shaking和Code Splitting等技术,以及如何使用这些技术来优化前端性能。最后还介绍了一些实用的工具,如Webpack、webpack-bundle-analyzer、性能测试工具等,以帮助开发人员更好地进行前端性能优化。
WeTest质量开放平台团队
2017/10/27
5K0
Web 前端性能优化 : 如何有效提升静态文件的加载速度
前端性能优化(四)——网页加载更快的N种方式
网站前端的用户体验,决定了用户是否想要继续使用网站以及网站的其他功能,网站的用户体验佳,可留住更多的用户。除此之外,前端优化得好,还可以为企业节约成本。那么我们应该如何对我们前端的页面进行性能优化呢?
呆呆
2021/09/30
3.5K0
网站前端性能优化
继前面几篇文章后再来说说老生常谈的话题,怎么样提升前端性能。文中很多取材自网络及《High Performance Web Sites》,并根据自己工作中所接触到的知识整理而成。
全栈程序员站长
2022/07/15
2.2K0
21道关于性能优化的面试题(附答案)
性能优化部分的面试题主要考察应试者对网站性能优化的了解。如何做好性能优化,哪些操作会引起性能优化的问题,性能优化指标是什么等,都值得应试者关注。
winty
2021/03/25
2K0
Web前端性能优化——如何有效提升静态文件的加载速度
作 者 刘轶斌,腾讯应用开发 工程师 商业转载请联系腾讯WeTest获得授权,非商业转载请注明出处。 WeTest 导读 此文总结了笔者在Web静态资源方面的一些优化经验。 如何优化 用户在访问网页时, 最直观的感受就是页面内容出来的速度,我们要做的优化工作, 也主要是为了这个目标。那么为了提高页面加载(或者渲染)速度呢?一般来说有三个方面: 1、代码逻辑:优秀的代码逻辑结构可以有效减少渲染页面使用的内存和速度(比如虚拟DOM),此方面不在本文讨论范围内。 2、SSR服务器渲染,也就是所谓的“直出”。将
WeTest质量开放平台团队
2023/05/04
2.1K0
Web前端性能优化——如何有效提升静态文件的加载速度
高性能网站建设指南-前端性能优化(一)
版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
奋飛
2019/08/15
7920
[转]雅虎前端优化的35条军规
80%的终端用户响应时间都花在了前端上,其中大部分时间都在下载页面上的各种组件:图片,样式表,脚本,Flash等等。减少组件数必然能够减少页面提交的HTTP请求数。这是让页面更快的关键。
w候人兮猗
2020/06/24
1.7K0
前端网络高级篇(六)网站性能优化
缺点是:此方案不适合mobile应用;IE7以下不支持;如果一张图片在多个页面被用到,无法利用浏览器缓存。 为了解决无法缓存问题,可以将data:image应用到CSS样式中,比如:
娜姐
2020/09/22
2K0
谈谈前端性能优化-面试版
当我们去面试的时候,很大概率会被面试官问这么一个问题:你有尝试过对项目做性能优化吗?或者你了解哪些性能优化的方法?听到这个问题的你可能是这样的:
loveX001
2022/10/11
1.3K0
【综合篇】Web前端性能优化原理问题
想要成为一名合格的Web前端工程师,Web前端性能优化是一个必须要掌握的知识,那么应该怎么进行Web前端性能优化呢?--达达前端
达达前端
2020/02/18
1.8K0
【综合篇】Web前端性能优化原理问题
页面性能优化的方法有哪些?
互联网有一项著名的8秒原则。用户在访问Web网页时,如果时间超过8秒就会感到不耐烦,如果加载需要太长时间,他们就会放弃访问。大部分用户希望网页能在2秒之内就完成加载。
一墨编程学习
2018/10/22
1.3K0
相关推荐
web前端性能优化
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档