京东6.18大促主会场领京享红包更优惠

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 2615|回复: 0

前端性能优化

[复制链接]

13

主题

0

回帖

10

积分

新手上路

积分
10
发表于 2019-5-19 01:59:46 | 显示全部楼层 |阅读模式 来自 中国
前端从环境搭建, 打包工具配置, 框架选型, 业务编码, 一直到发布上线后的用户数据监控整个生产链上涉及到的方面很多, 为了提高开发体验和用户体验, 前端可以进行很方面的优化, 本结前端优化特指为了提高前端上线后的用户体验而进行页面性能优化这块, 就是让用户等的时间短,尽快的可以进行页面交互.用公式记录一下:
- }" ]9 \" G: K) l; L优化 = 性能优化 + .... E! [; {5 i" e
性能优化 = 用户体验 + ... ' ^+ l6 {# L$ d# O; F
性能度量
5 _) N2 F- M6 [% K8 i有人做了下面一个表格# s4 X3 Y! K4 j6 e
用户体验描述% g! J- l$ p; l8 A; E
为了更好的用户体验, 我们从网页加载和渲染两个维度进行优化, 公式:  D  W. V3 |! z
用户体验 = 加载性能 + 渲染性能 + ...7 r) X9 Y; l" _/ t( ^; N- S
性能监控
2 f+ ~" N- w  m6 e2 |' J性能监控是性能优化的第一步,至关重要,因为只有性能监控才能找到性能瓶颈,然后会对性的进行优化.
& w0 c/ g% R$ {9 N; U3 I5 i监控工具: Lighthouse
# M4 W; ^8 s3 r- o: n! hLighthouse是一个Google开源的自动化工具,主要用于改进网络应用(移动端)的质量。目前测试项包括页面性能、PWA、可访问性(无障碍)、最佳实践、SEO。Lighthouse会对各个测试项的结果打分,并给出优化建议,这些打分标准和优化建议可以视为Google的网页最佳实践。6 Z& {- [$ R$ y7 Q1 H
Lighthouse 三种使用方法:
! g/ d  s" ]) j; s) A" e$ E1. Chrome60及以上的开发者工具的audits面板还不是Lighthouse。5 G8 ^% [4 U. C4 @: f
2. Chrome拓展程序
3 w# Y% ^' ^- _! R4 T3. 命令行工具 npm install -g lighthouse or yarn global add lighthouse
; u  V5 t# f( Y7 x: Q- \2 rLighthouse 原理: " O% X* Y( B1 e, S. }
关于前端性能指标,W3C 定义了强大的Performance API,其中又包括了 High Resolution Time 、 Frame Timing 、 Navigation Timing 、 Performance Timeline 、Resource Timing 、 User Timing 等诸多具体标准. User Timing 、Navigation Timing 以及 Resource Timing。截至到 2018 年中旬,各大主流浏览器均已完成了基础实现. 而 Lighthouse 主要使用设备Chrome浏览器新的API PerformanceObserver, PerformanceEntry, 以及 DOMHighResTimeStamp 等.* `* l+ ?/ n2 |2 f
3 `7 M. H7 W' H  }6 W2 r
性能优化
( x( s8 K* `9 Y( `. e, `4 l分析监控数据,就可以针对性地对网页进行优化, 下面是具有普适性的参考优化点, 在平时的开发中应该多多注意
/ C. ~& B  }: ]- b加载优化; p! L# e4 q1 T) f/ q0 g
网页资源加载即客户端展示的所有数据加载, 包括 静态资源 及 动态数据
% c0 @2 @4 d! X9 z: M' N0 o% L1. 静态资源
0 G3 L. \; o1 C4 r, ka) Js css img等合并压缩和雪碧图# G* D3 h; l2 Q1 i/ [' H) }
b) cdn内容分发) |) i9 D% y* i; r
c) 各种缓存(dns缓存,ip缓存, 服务器缓存, 客户端缓存)0 g$ s9 C5 M- M( ~
d) 内容分片8 Y! t! B, Z2 {6 k" j  p
e) 协议(http2)
6 j7 F0 {# B* }; B* j5 q2. 业务数据+ U% f: d$ \3 F+ H* }
a) spa首屏直出(ssr或骨架屏或预渲染)
: w: _9 L9 `6 I+ I( A2 kb) 接口合并: E8 {" {2 w5 x9 \7 J6 |
渲染优化( C; t, V9 P" F: J8 s) \2 B. T
网页渲染) V0 |% d+ u" o# g" `) f
1. 防止阻塞渲染
3 X: f$ }: s8 g+ V3 S2. 减少重绘和回流
1 \& U6 H1 K$ T  X# S% V8 h; }' _3. 提高代码质量
, D$ B5 x9 V1 I9 J0 @' T/ K6 a
  |3 ]" s1 C' v7 c* @6 }来源:https://www.toutiao.com/a6692409042528109064/  T/ P( {  ]; o
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×

帖子地址: 

梦想之都-俊月星空 优酷自频道欢迎您 http://i.youku.com/zhaojun917
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|梦想之都-俊月星空 ( 粤ICP备18056059号 )|网站地图

GMT+8, 2025-11-2 09:09 , Processed in 0.037023 second(s), 25 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表