前端面试题之性能优化大杂烩2

JavaScript相关优化

  1. 把脚本放在页面底部
    放在前面js加载会造成阻塞,影响后面dom的加载

  2. 使用外部JavaScript和CSS
    在现实环境中使用外部文件通常会产生较快的页面,因为 JavaScript 和 CSS 有机会被浏览器缓存起来。对于内联的情况,由于 HTML 文档通常不会被配置为可以进行缓存的,所以每次请求 HTML 文档都要下载 JavaScript 和 CSS。所以,如果 JavaScript 和 CSS 在外部文件中,浏览器可以缓存它们,HTML 文档的大小会被减少而不必增加 HTTP 请求数量。

  3. 压缩JavaScript和CSS
    压缩文件是为了降低网络传输量,减少页面请求的响应时间。

  4. 减少DOM操作
    操作dom会产生几种动作,极大的影响渲染的效率。其中layout(布局)和paint(绘制)是最大的。

  5. js开销缩短解析时间
    开销:加载-》解析和编译-》执行
    js的解析和编译,执行要花很长时间(谷歌开发工具中的performance中可以查看。选中main主线程中的某一段。)
    解决方案:

    • 代码拆分按需加载
    • tree shaking代码减重
    • 避免长任务
    • requestAnimationFrame和repuestIdleCallback进行时间调度
  6. v8编译原理(代码优化)

    • 解析js代码成抽象语法树-》字节码-》机器码
      编译过程会进行优化
      运行时可能会发生反优化
    • v8内部优化
      脚本流:边下载边解析
      字节码缓存:常用的字节码会存起来(这个文件用到其他的文件也用到的参数)
      函数懒解析:先解析用到的
    • 对象优化(迎合v8进行优化)
      保证对象初始化顺序一致(对象初始化时v8会生成隐藏属性以便后续复用并且是按照顺序排序的)
      不要直接赋值对象新属性(追加的属性需要通过描述数组间接查找)
      使用数组代替类数组(v8会对数组进行优化)比如先将类数组转化成数组
      避免读取数组越界(比如for循环多查找1个下标会照成性能相差6倍)

造成undefined和数字比较
数组也是对象,当找不到对应下标的时候回沿着原型链向上找造成额外开销
业务上无效

  1. js内存,避免造成内存泄漏
    通过变量是否能被访问到来判断内存是否释放。
  • 局部变量: 函数执行完没有闭包引用会被标记回收
  • 全局变量: 直到浏览器被卸载页面释放
  • 回收机制:
    引用计数:每调用一次加一,当计数为0的时候进行回收。缺点是不能解决循环引用(例如a对象依赖于b对象,标记清除(垃圾回收): 从根节点去访问,当访问到不能被访问的对象就进行标记然后进行垃圾回收。(当a对象
    解决:避免意外的全局变量;避免反复运行引发的闭包;避免脱离的dom元素没有被回收(所以react有ref这个api)。

CSS 相关优化

  1. 把样式表放在<head>标签中
    css放在head标签中比css放在body标签尾部少了一次构建RenderTree, 一次计算布局和一次渲染网页, 因此性能会更好。
  2. 不要使用CSS样式表
  3. 使用<link>替代@import
  4. 不要使用filter
  5. 避免元素类型转化(数组中放多种类型不利于v8引擎优化代码)
    • 降低css对渲染的阻塞(按需加载,放在dom前面加载)
    • 利用pu完成动画(前面讲到的复合)
    • 使用contain进行优化(优化强度大。例如: contan:layout告诉浏览器这个节点内部的子元素和外面的使用font-display进行优化:让文字更早的显示在页面上,减轻文字闪动的问题

html 相关优化

  1. 减少iframes使用
  2. 压缩空白符
  3. 避免嵌套层次太深
  4. 避免使用table布局
  5. 减少没必要的注释
  6. 删除元素默认属性(比如默认checkbox等)

开发内容相关优化

  1. 减少HTTP请求数
  2. 减少DNS重定向
  3. 缓存AJax请求
  4. 延迟加载
  5. 预加载
  6. 减少DOM元素的数量
  7. 划分内容到不同域名
  8. 尽量减少使用iframe
  9. 避免404错误

服务器相关优化

  1. 使用CDN
  2. 添加Expires或Cache-Control响应头
  3. 启用Gzip
  4. 配置Etag
  5. 尽早输出缓冲
  6. Ajax请求使用GET方法
  7. 避免图片src为空
  8. 传输加载优化
    服务器启用gzip
  9. keep Alive(持久TCP连接)
    keepalive_requests 100;请求100次后开启http的keepAlive有keepalive_timeout 65;65秒后关闭。
  10. http缓存
    最好是用no-cache(要用的时候需要在服务器那边Etag验证下)
  11. service workers
    • 加速重复访问
    • 离线支持

Cookie相关优化

  1. 减少cookie大小
  2. 静态资源使用无cookie域名

首屏加载优化

  1. 资源压缩、传输压缩、代码拆分、tree shaking、http缓存
  2. 路由懒加载、预渲染、inlineCss、虚拟列表
  3. prefetch和preload调整加载顺序js内存管理
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352

推荐阅读更多精彩内容