注意这 3 个小细节, Web 性能再提升一档!

注意这 3 个小细节, Web 性能再提升一档!

打开今日头条,查看更多图片

为什么web性能如此重要?

真的非常重要!

响应更快的网站会带给用户更好的体验,理论上讲,好的体验等于好的用户满意度。更快,也意味着用户在放弃之前,有希望更快的访问到你的网站。放弃的原因有很多:页面加载时间太长,用户失去了兴趣,浏览器崩溃等等。提高性能可以降低放弃率,会给网站了带来显著的效益。

运行时的性能是指web应用程序运行时对于用户输入的响应速度,比如点击删除图片等。

Web性能影响因素

注意这 3 个小细节, Web 性能再提升一档!

运行时的性能受很多因素影响:

  • 从完成特定功能所采用的算法效率到优化方法;
  • 从解释器和浏览器渲染引擎的优化或不足到有效内存管理和CPU使用率;
  • 再到设计时间同步和异步操作之间的选择,都会对性能产生影响。运行时的性能是一个比较主观的感觉。 今天就从三个角度分享一下小编的性能优化小技巧。

角度一:当我们在浏览器的地址栏输入一个URL,就开启了一个新的网络线程,DNS解析、TCP连接和HTTP请求和响应,不可避免地依赖网络环境、受到网络延迟、网络不稳定等因素影响。我们能做的只有尽可能减少网络请求,以减少网络线程产生的网络消耗。

角度二:浏览器也有部分原因,主流浏览器有IE、Chrome、Safari、Firefox、Opera等,不同的浏览器的JS引擎性能不同,带给用户的体验也不同,比如IE8及以下的内核表现不好是众所周知的。

角度三:除去网络、浏览器等外围因素,影响web性能的主要还是页面本身。作为开发人员,性能优化可以控制的部分就是页面,包括页面大小、页面结构、JS、CSS等等。

针对以上3点页面加载过程所涉及到的因素,下面做简单讨论和优化的办法介绍~

性能优化小技巧

注意这 3 个小细节, Web 性能再提升一档!

1、减少HTTP请求数:

1)资源大小很重要,不仅仅关系到下载时间,还因为IPv4和IPv6协议规定一个IP包的最大值为65535字节。一个IP包是一次请求,于是可以得到一个等式:

注意这 3 个小细节, Web 性能再提升一档!

根据这个公式,我们可以控制资源尽可能小。可以采取使用gulp等自动化构建工具进行自动合并JS文件、压缩文件和图片等手段。

2) 避免重定向:重定向说明需要客户端采取进一步操作才能完成请求,请求时间就会延长。所以输入URL时应使用最完整的、最直接的地址,比如输入www.baidu.com而不是baidu.com。

3) 使用缓存机制:主要有数据库缓存、服务端缓存(反向代理和CDN缓存)、浏览器缓存。

2、 图片懒加载

页面图片很多的,可以使用懒加载。只加载第一屏的图片,当用户滚动访问后面的内容时再加载相应图片。方法是先用一张极小的占位图代替图片,占位图只下载一次,将原本图片的src存储在另一个属性中,判断当图片快进入可视区域就将路径赋值给src并下载图片进行展示。下面是简单的例子:

注意这 3 个小细节, Web 性能再提升一档!

3、代码优化

1)页面结构:CSS放在HTML内容上部,JavaScript放在HTML内容下部。可以使用preload提前解析资源的DNS。由于浏览器是自上而下读取内容的,因此放置资源的位置会影响网站的访问速度。比如,如果将script标签放在HTML内容的前边,浏览器就会先调用JavaScript解释器对JS进行解析,完成之后才会渲染其余的HTML内容,对用户来说,能看到的是HTML的内容,所以1) 这么做会导致页面可用性的延迟。另外,CSS是对页面节点进行修饰的,如果CSSOM未构建之前就进行了布局,等到CSSOM构建出来,如果CSS修改了节点的布局,就会发生重排,需要重新计算布局并绘制。

2) JavaScript优化:比如减少对DOM的操作,减少重排和重绘,减少作用域链查找,慎用eval函数等等。JS代码和(下面的)CSS的优化主要要求前端开发人员对页面渲染原理有清晰的了解、对基础知识的掌握和良好的编程习惯。

3) CSS优化:比如减少使用通配符‘*’,提取公用样式增强可复用性,选择器准确可减少匹配时间,适度使用内联样式。

注意这 3 个小细节, Web 性能再提升一档!

打开APP阅读全文

今日头条

现代社会,不被陌生电话打扰成为一种奢望。”、“你需要投资吗”,几乎我们每个人或多或少都接到过类似的骚扰电话。

注意这 3 个小细节, Web 性能再提升一档!

放弃的原因有很多:页面加载时间太长,用户失去了兴趣,浏览器崩溃等等。运行时的性能是指web应用程序运行时对于用户输入的响应速度,比如点击删除图片等。

分享:SQL 注入攻防入门详解

毕业开始从事winfrm到今年转到web,在码农届已经足足混了快接近3年了,但是对安全方面的知识依旧薄弱,事实上是没机会接触相关开发。

如何实现一个权限管理系统?

系统安全一直是在系统开发中不可规避的问题,而权限控制又跟系统…一个个的标签保存在数据库中,用户的权限中持有对应的标签则表示拥有对应的操作权限。而对于hiro的授权,在doetuthorizationnfo中需要获取用户的所有权限列表,通过权限列表筛选出是否拥有操作权限。//hiro进行授权@verri… o、、ransaction、 归纳小结(完)(java思维

网站推广中如何做好网站架构?

做好网站架构有两个好处,一个是提升用户体验,一个是利于搜索引擎排名优化。一般的网站架构要以树形结构为主,层级清晰且不要太多,中小型网站层级不要超过三级。网站架构还要看网站的类型及用途,网站分很多种类,:-架构,网站推广,网站,推广:网站推广中如何做好网站架构?