当面试官问你如何进行性能优化时,你该这么回答(一)

背景

在开发好页面后,如何让页面更快更好的运行,是区分一个程序猿技术水平和视野的一个重要指标。所以面试时,面试官总会问你一个问题,如何进行性能优化呢?

如果你这时是头脑一片空白,或是像之前的我一样,靠死记硬背或是之前的经历,答一下压缩代码,打包代码,雪碧图,cdn,事件代理,这说明你对性能优化还是缺乏一个整体,系统的掌握,对性能优化还只是处于听说过一个方法就加上去的阶段。这样也就无从去更好的优化性能。

最近一个星期经过疯狂的面试和查询资料,我总算积累了一些经验和思考,在这个招聘的黄金时间,分享给大家,希望大家可以有一点收获。如果有收获,欢迎关注和star一下博客github

性能优化是什么

从前端的角度来说,性能优化可以分为两个方向。从用户角度来看,一个是页面加载的很快,另一个是页面使用起来很流畅。因此,对性能优化的探索,我们可以分为页面加载时间跟页面运行效率两个方向来进行研究

从浏览器打开到页面渲染完成,花费了多少时间

是的,这个问题有点熟悉,面试官比较常问的是从浏览器打开到页面渲染完成,发生了什么事情。这个问题网上很多回答,我也不就重复的细说了。主要的过程是:

浏览器解析->查询缓存->dns查询->建立链接->服务器处理请求->服务器发送响应->客户端收到页面->解析HTML->构建渲染树->开始显示内容(白屏时间)->首屏内容加载完成(首屏时间)->用户可交互(DOMContentLoaded)->加载完成(load)

很显然,如果我们要进行加载时间的优化,我们需要从这里的每一个步骤都去思考,去总结,而避免东凑一点,西凑一点。

页面加载时间监控

有一句话说得好,If You Can't Measure It, You Can't Manage It。在对这些环节进行优化之前,我们需要知道如何监控这些环节花费了多少时间。

首先推荐一个PerformanceTiming,可以获取到很多页面加载相关的数据。 比较常用的有

DNS解析时间: domainLookupEnd - domainLookupStart
TCP建立连接时间: connectEnd - connectStart
白屏时间: responseStart - navigationStart
dom渲染完成时间: domContentLoadedEventEnd - navigationStart
页面onload时间: loadEventEnd - navigationStart

复制代码

如果不使用该API,可以以服务器渲染返回的时间,或是SPA路由跳转离开的时间为起点,domContentLoaded,load等事件为结束点进行记录。或是直接上google analytics。方法很多,就不细说了。

服务器部分优化要点

后端部分可以对缓存,dns查询时间,链接时间,处理请求时间,响应时间等进行优化。

缓存就不细说了。

dns查询时间可以使用httpdns或是dns预加载,域名收敛等手段优化。我还写了篇介绍DNS和CDN的文章

建立连接的重点是长连接和链接复用,keep-alive,long-polling,http-straming,websocket或是自己写过别的协议,更好的是直接上http2。为了优化链接的环节,前端这里还需要对资源使用cdn,雪碧图,代码合并等手段。

服务器处理请求这里可以优化的点也不少,值得注意的就是移动端访问PC端页面需要跳转到移动端页面时,要再服务器端使用302跳转,不要在前端进行跳转。还有就是启用hsts,要求浏览器在之后的访问使用https,减少无谓的http跳转https,同时还可以防止ssl剥离攻击,提升安全性。

服务器发送响应环节,可以使用Transfer-Encoding=chunked,多次返回响应,具体操作查询bigpipe。还有就是减小cookie的体积等等。

前端部分优化要点

前端部分可以对白屏时间,首屏事件,可交换时间,加载完成时间进行优化。

-未完,待续-

博客文章链接web性能优化(一)github,欢迎star和follow,谢谢!

有时间的同学也可以看下我的文章大厂前端面试考什么? ,应该也有帮助

转载于:https://juejin.im/post/5a99f80cf265da238c3a1e16

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 作为一个前端开发者,我认为自己具备良好的前端技术。我熟悉HTML、CSS、JavaScript等基础技术,并且掌握了常用的前端框架和工具,如React、Vue、Webpack等。我对前端开发的趋势和新技术保持着持续的学习和关注,以便更好地适应市场的需求。同,我也注重代码的可维护性和可扩展性,采用模块化的开发方式来提高代码的复用性和可读性。总的来说,我相信我具备良好的前端技术能力,并且能够胜任相关的工作。 ### 回答2: 如果面试官我:“你觉得你前端技术怎么样?” 我会这样回答: 首先,我对我的前端技术非常自信。我有坚实的HTML、CSS和JavaScript基础,并且对前端开发的各种技术和工具都有一定的了解和应用经验。 我注重学习和保持对最新前端技术的敏感性,积极关注业界的发展趋势和新兴技术。我经常阅读相关的博客、文章和书籍,不断提升自己的技术水平。 我还熟悉常用的前端框架,例如React和Vue,能够灵活地运用它们来构建用户友好的界面和交互体验。 在项目开发中,我能够编写结构清晰、可维护和可扩展的代码。我了解前端性能优化的重要性,注重页面加载速度和响应性能方面的优化。 我对团队合作非常热衷,能够与设计师和后端开发人员紧密合作,高效地完成项目。我也有良好的沟通技巧,能够与非技术背景的人员进行有效的沟通。 虽然我的前端技术已经达到了一定的水平,但我相信学习永无止境。我会不断学习新的技术和提升自己的技能,以满足日益变化的前端行业需求。 总结起来,我认为我的前端技术扎实且有潜力,我准备在工作中充分发挥我的技术能力,与团队共同努力,创造出优秀的产品和用户体验。 ### 回答3: 面试官:你觉得你前端技术怎么样。 回答:非常感谢您的提。我对自己的前端技术有一定的自信。在过去的工作经验中,我参与并负责了多个前端项目的开发,积累了一定的技术经验和实践经验。我熟悉HTML5、CSS3、JavaScript等前端技术,并能熟练运用各类前端框架和工具,如Vue.js和React等。 我注重用户体验和界面设计,擅长将设计稿转化为高质量的页面代码,并能够根据产品需求进行页面优化和响应式开发。同,我对前端性能优化也有一定的了解,能够通过优化网页加载速度和资源的使用来提升用户访体验。 我还具备良好的团队合作能力和沟通能力。在团队中,我能够与设计师、后端工程师和产品经理紧密配合,理解并满足他们的需求。我也积极参加技术交流活动,不断学习新知识和掌握新技术,以保持对行业的敏感度和追求卓越的态度。 当然,前端技术是一个不断发展和涵盖多个领域的领域,我还有继续提升的空间。我会持续关注前端技术的最新动态,并愿意学习和应用新的技术来解决实际题。我相信,通过我的努力和坚持,我能够在前端领域取得更好的成长和发展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值