在分享这篇文章之前呢,我先分享下我总结的一些干货,我自己是一名从事了7年web前端开发的全栈工程师,辞职目前在做线上教育讲师,今年年初我花了一个月整理了一份最适合2018年学习的web前端干货,包括基础+源码+资料+视频,都是免费的,在这里相信有许多想要学习web前端的同学,关注小编头条号,私信"学习"即可
面试对于程序员来说是实打实的,没有点真功夫也进不去公司的,HR会尽可能问到你所有的知识,回答不上当然就不会需要你了,哪怕是回答不够好你之后的面试结果,薪资都是很大的问题。那么性能优化如何解答呢?
一、页面重构怎么操作?
网站重构:在不改变外部行为的前提下,简化结构、添加可读性,而在网站前端保持一致的行为。 也就是说是在不改变UI的情况下,对网站进行优化,在扩展的同时保持一致的UI。 对于传统的网站来说重构通常是: 表格(table)布局改为DIV+CSS 使网站前端兼容于现代浏览器(针对于不合规范的CSS、如对IE6有效的) 对于移动平台的优化 针对于SEO进行优化 深层次的网站重构应该考虑的方面 减少代码间的耦合 让代码保持弹性 严格按规范编写代码 设计可扩展的API 代替旧有的框架、语言(如VB) 增强用户体验 通常来说对于速度的优化也包含在重构中 压缩JS、CSS、image等前端资源(通常是由服务器来解决) 程序的性能优化(如数据读写) 采用CDN来加速资源加载 对于JS DOM的优化 HTTP服务器的文件缓存
二、什么叫优雅降级和渐进增强?
优雅降级:Web站点在所有新式浏览器中都能正常工作,如果用户使用的是老式浏览器,则代码会针对旧版本的IE进行降级处理了,使之在旧式浏览器上以某种形式降级体验却不至于完全不能用。
如:border-shadow
渐进增强:从被所有浏览器支持的基本功能开始,逐步地添加那些只有新版本浏览器才支持的功能,向页面增加不影响基础浏览器的额外样式和功能的。当浏览器支持时,它们会自动地呈现出来并发挥作用。
如:默认使用flash上传,但如果浏览器支持 HTML5 的文件上传功能,则使用HTML5实现更好的体验;
三、前端性能优化的方法?
1、减少http请求次数:CSS Sprites, JS、CSS源码压缩、图片大小控制合适;网页Gzip,CDN托管,data缓存 ,图片服务器。2、 前端模板 JS+数据,减少由于HTML标签导致的带宽浪费,前端用变量保存AJAX请求结果,每次操作本地变量,不用请求,减少请求次数3、 用innerHTML代替DOM操作,减少DOM操作次数,优化javascript性能。4、 当需要设置的样式很多时设置className而不是直接操作style。5、少用全局变量、缓存DOM节点查找的结果。减少IO读取操作。6、 避免使用CSS Expression(css表达式)又称Dynamic properties(动态属性)。7、 图片预加载,将样式表放在顶部,将脚本放在底部 加上时间戳。8、避免在页面的主体布局中使用table,table要等其中的内容完全下载之后才会显示出来,显示比div+css布局慢。
四、页面从输入 URL 到页面加载显示完成
1.浏览器根据请求的URL交给DNS域名解析,找到真实IP,向服务器发起请求;2.服务器交给后台处理完成后返回数据,浏览器接收文件(HTML、JS、CSS、图象等);3.浏览器对加载到的资源(HTML、JS、CSS等)进行语法解析,建立相应的内部数据结构(如 HTML的DOM);4.载入解析到的资源文件,渲染页面,完成。
五、平时如何管理你的项目?
先期团队必须确定好全局样式(globe.css),编码模式(utf-8) 等;编写习惯必须一致(例如都是采用继承式的写法,单样式都写成一行);标注样式编写人,各模块都及时标注(标注关键样式调用的地方);页面进行标注(例如 页面 模块 开始和结束);CSS跟HTML 分文件夹并行存放,命名都得统一(例如style.css);JS 分文件夹存放 命名以该JS功能为准的英文翻译。图片采用整合的 images.png png8 格式文件使用 尽量整合在一起使用方便将来的管理
专业的知识在面试自然发挥还是要多一点自然,从自己嘴里说出来就像是自己的东西。HR永远都是纸老虎,只有你满满的自信才能打败他,到体无完肤,加油!
留言与评论(共有 0 条评论) |