首页
技术博客
PHP教程
数据库技术
前端开发
HTML5
Nginx
php论坛
新用户注册
|
会员登录
PHP教程
技术博客
编程问答
PNG素材
编程语言
前端技术
Android
PHP教程
HTML5教程
数据库
Linux技术
Nginx技术
PHP安全
WebSerer
职场攻略
JavaScript
开放平台
业界资讯
大话程序猿
登录
极速注册
取消
热门标签 | HotTags
datetime
loops
const
select
controller
int
list
hashcode
split
chat
go
tags
jar
join
range
instance
replace
erlang
regex
uml
case
substring
hashtable
dagger
hash
audio
require
flutter
php8
client
filter
nodejs
web3
golang
stream
buffer
search
eval
format
future
merge
bytecode
bash
io
uri
bit
foreach
char
scala
cookie
express
blob
random
vbscript
lua
cPlusPlus
php7
settings
keyword
vba
version
plugins
input
spring
javascript
object
ascii
timezone
数组
frameworks
httprequest
usb
default
c语言
hook
match
bitmap
integer
install
当前位置:
开发笔记
>
编程语言
> 正文
测试关注指标记录点
作者:洱冬橙66_156 | 来源:互联网 | 2023-08-08 19:08
”加载速度“的主要关注点如下:网络WIFI4G3G2G启动白屏时间首屏时间可交互时间缓存有缓存无缓存缩短响应时间CDN部署合理分域名HTTP请求数资源合并HTTP状态失败资源处理单
”加载速度“ 的主要关注点如下:
网络
WIFI/4G/3G/2G
启动
白屏时间
首屏时间
可交互时间
缓存
有缓存
无缓存
缩短响应时间
CDN部署
合理分域名
HTTP请求数
资源合并
HTTP状态
失败资源处理
单个请求优化
缓存机制
压缩内容
资源合理组合
预加载
分页加载
CSS放顶部
js放底部
测试关注指标:
HTTP请求个数【是否有多余的请求,示例:后端可做的请求放在了前段去实现(注:公共的加载项除外)】
一个网页最终到达终端用户有80%的时间都是在js,CSS,图片,mp3,flash等资源的http请求。另一方面,http请求的数量也是有限制的,浏览器对同一个域名有连接数限制,不同浏览器内核、不同版本的请求数不尽相同,大部分的并发请求数是6个。
问题:什么样的请求应该由后端去做?什么样的请求必须由前端来实现?
组件是否压缩
压缩方法:在http请求中设置所接受到压缩方式,在Server端对Response资源进行压缩再传给浏览器。一般使用GZIP设置content-Encoding字段。Transfer-Encoding: chunked
压缩对象:从http请求返回资源中的html,js,CSS,xml等都可以设置压缩,值得注意的是我们不需要对图片音乐等资源设置压缩,因为这些资源本身已经压缩过了,再次压缩收益并不高,而且增加CPU负担。
问题:什么情况下才会做压缩?哪些文件支持压缩?压缩的利弊?
图片格式和大小是否合适
图片格式:显示效果较好的图片格式中,有webp、jpg和png24/32这几种常见的图片格式,webp的图片最小
图片尺寸:获取图片尺寸时候应该考虑图片具体的展示场景,如当前移动设备中常用个尺寸规格为480×800、600×1024、720×1280,800×1280等,从原图来保证图片能够被呈现,而不是通过代码对图片放大或缩小。
图片压缩:对于jpg,png格式图片来说本身就已经经过了压缩,这对于稀缺的带宽资源是不够的,我们还需要更加优化的压缩算法,通过一系列的图片压缩工具如TinyPNG, Smush.it可以得到更好的压缩且图片质量不变。
问题:jpeg的图片格式跟jpg图片格式的区别?图片的尺寸对加载性能上的影响大不?图片的大小一般建议不超过多少KB?
css放在顶部(CSS和js代码是否有做分离):
在浏览器渲染过程中谈到,dom树构建完成后。CSS要放到html代码的开头的head标签结束前。如果网页是动态生成的,那么在head代码完成后可以页面输出,这样浏览器就会更快地解析出来head中的内容,开始下载CSS文件资源。而CSS放在底部则会引起重新绘制,用户侧感受到“闪屏”的不好体验。
问题:CSS和js代码什么情况下适合做分离?什么情况下是不可以做分离的?
js放在底部
JS在下载的时候会引起两个问题:阻止网页内容的展示并阻止其他资源下载。在“减少http数量”部分中,我们谈到各种资源的下载是并行的,根据不同域名不同浏览器内核并行数量有所不同,所以下载js时候,并行下载机制失效。并且在js中可能包括document.write等改变页面布局的操作,所以渲染引擎会等待js下载完成再开始渲染。所以用户侧页面加载时间会因为等待而变得更长。
js&css压缩
从js&CSS文件的源头进行压缩,缩小了http传输过程数据大小。
是否添加缓存
缓存的优点:缓存接口数据,在一些数据新旧敏感性不高的场景下很有用,在非首次加载数据时候优先使用上次请求来的缓存数据,可以让页面更加快速地渲染出来,而不用等待一个新的HTTP请求结束之后再渲染。
两种方式设置缓存,测试时注意常用资源是否请求资源时否设置缓存Cache-Control:
"no-cache"指示请求或响应消息不能缓存(HTTP/1.0用Pragma的no-cache替换)
"no-store"用于防止重要的信息被无意的发布。在请求消息中发送将使得请求和响应消息都不使用缓存。根据缓存超时Expires 表示存在时间,允许客户端在这个时间之前不去检查(发请求),等同max-age的效果。
问题:什么样的请求类型才会做缓存?哪些文件适合做缓存?一般的缓存方式有哪些?
避免非200返回值
如果有http请求返回为非200的状态码,我们认为这一次请求时无意义的,占用了稀缺的网络资源,所应该避免非200的返回状态码。
使用CDN
CDN内容分发网络(Content Delivery Network)将源站内容发布到最接近用户的“边缘”节点,使用户可就近取得所需内容,提高用户访问的响应速度和成功率。解决因分布、带宽、服务器能力带来的访问延迟高问题。
问题:哪些内容才会用到cdn的分发?
页面的加载方式?(是否有懒加载、预加载)
时间
白屏时间:用户首次看到网页有内容的时间,即第一次渲染流程完成时间。
首屏时间:是指用户看到第一屏,即整个网页顶部大小为当前窗口的区域,显示完整的时间。
首资源下载时间:从开始下载到第一个资源均下载完成的时间,不包括页面绘制时间。
总资源下载时间:从开始下载到所有资源均下载完成的时间,不包括页面绘制时间。
用户可操作时间:从页面开始加载到用户操作可响应的时间。
android
asp.net
ios
php
jsp
数据库
wifi
缓存
cdn
写下你的评论吧 !
吐个槽吧,看都看了
会员登录
|
用户注册
推荐阅读
http
网络爬虫的规范与限制
本文探讨了网络爬虫引发的问题及其解决方案,重点介绍了Robots协议的作用和使用方法,旨在为网络爬虫的合理使用提供指导。 ...
[详细]
蜡笔小新 2024-11-13 15:45:41
http
自动验证时页面显示问题的解决方法
在使用自动验证功能时,页面未能正确显示错误信息。通过使用 `dump($info->getError())` 可以帮助诊断和解决问题。 ...
[详细]
蜡笔小新 2024-11-13 12:30:21
int
面试中如何回答“零拷贝”技术问题?
零拷贝技术是提高I/O性能的重要手段,常用于Java NIO、Netty、Kafka等框架中。本文将详细解析零拷贝技术的原理及其应用。 ...
[详细]
蜡笔小新 2024-11-13 02:03:52
int
微信小程序详解:概念、功能与优势
微信公众平台近期向200位开发者发送了小程序的内测邀请。许多人对微信小程序的概念还不是很清楚。本文将详细介绍微信小程序的定义、功能及其独特优势。 ...
[详细]
蜡笔小新 2024-11-12 19:35:21
int
自定义滚动条美化页面内容
当页面内容超出显示范围时,为了提升用户体验和页面美观,通常会添加滚动条。如果默认的浏览器滚动条无法满足设计需求,我们可以自定义一个符合要求的滚动条。本文将详细介绍自定义滚动条的实现过程。 ...
[详细]
蜡笔小新 2024-11-12 17:12:24
go
Framework7:构建跨平台移动应用的高效框架
Framework7 是一个开源免费的框架,适用于开发混合移动应用(原生与HTML混合)或iOS&Android风格的Web应用。此外,它还可以作为原型开发工具,帮助开发者快速创建应用原型。 ...
[详细]
蜡笔小新 2024-11-12 14:47:56
go
CMD 批处理脚本示例
本文介绍了如何使用 CMD 批处理脚本进行文件操作,包括将指定目录下的 PHP 文件重命名为 HTML 文件,并将这些文件复制到另一个目录。 ...
[详细]
蜡笔小新 2024-11-12 14:26:04
go
rewrite nginx
两个条件,组合控制#if($query_string~*modviewthread&t(&extra(.*)))?$)#{#set$itid$1;#rewrite^ ...
[详细]
蜡笔小新 2024-11-12 13:55:01
go
DMA控制器与外设请求映射表详解
本文详细介绍了DMA控制器如何通过映射表处理来自外设的请求,包括映射表的设计和实现方法。 ...
[详细]
蜡笔小新 2024-11-12 13:51:55
case
单片微机原理P3:80C51外部拓展系统
外部拓展其实是个相对来说很好玩的章节,可以真正开始用单片机写程序了,比较重要的是外部存储器拓展,81C55拓展,矩阵键盘,动态显示,DAC和ADC。0.IO接口电路概念与存 ...
[详细]
蜡笔小新 2024-11-12 19:51:29
case
网站访问全流程解析
本文详细介绍了从用户在浏览器中输入一个域名(如www.yy.com)到页面完全展示的整个过程,包括DNS解析、TCP连接、请求响应等多个步骤。 ...
[详细]
蜡笔小新 2024-11-12 18:13:16
case
Dell Latitude 5290 2-in-1 平板电脑黑苹果体验评测
本文基于notebookcheck的详细数据和个人实际使用体验,对Dell Latitude 5290 2-in-1平板电脑进行评测。评测内容包括外观设计、散热性能、基准测试、游戏表现和续航能力等方面,旨在为读者提供全面的参考。 ...
[详细]
蜡笔小新 2024-11-12 17:24:30
instance
c/c++常用代码doc,ppt,xls文件格式转PDF格式[转]
[转]doc,ppt,xls文件格式转PDF格式http:blog.csdn.netlee353086articledetails7920355确实好用。需要注意的是#import ...
[详细]
蜡笔小新 2024-11-12 16:19:40
go
window下的python安装插件
window下的python安装插件,Go语言社区,Golang程序员人脉社 ...
[详细]
蜡笔小新 2024-11-12 15:14:05
go
解决Bootstrap DataTable Ajax请求重复问题
在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ...
[详细]
蜡笔小新 2024-11-12 13:59:27
洱冬橙66_156
这个家伙很懒,什么也没留下!
Tags | 热门标签
datetime
loops
const
select
controller
int
list
hashcode
split
chat
go
tags
jar
join
range
instance
replace
erlang
regex
uml
case
substring
hashtable
dagger
hash
audio
require
flutter
php8
client
RankList | 热门文章
1
我想去北大青鸟的IT培训 大家给个建议
2
A级课程 从零开始(七)ssd 24训练部分 收尾补充(IOU, NMS)
3
强迫症亲测:Windows10秋季创意者更新(转载):win10切换win7风格菜单
4
开发笔记:left join 后用 on 还是 where,区别大了!
5
jsp高校学生宿舍公寓管理系统功能最全
6
轻松入门普罗米修斯
7
Hadoop——你不得不了解的大数据工具
8
《关于我的那些面经》——百度后端(附答案)
9
更多|台账_在线问题反馈模块实战:封装通用字段类
10
波形|节拍_fpga实操训练(ip ram和ip fifo)
11
我正在尝试旋转图像,但是图像在枢轴点旋转
12
print spooler启动失败 in Adobe Acrobat installing
13
MySQL 安全管理
14
Java性能优化:Stream如何提高遍历集合效率?
15
限定概率抽奖_王者荣耀多款福利皮肤,连续王者免费得史诗,战令皮肤抽奖返场开启...
PHP1.CN | 中国最专业的PHP中文社区 |
DevBox开发工具箱
|
json解析格式化
|
PHP资讯
|
PHP教程
|
数据库技术
|
服务器技术
|
前端开发技术
|
PHP框架
|
开发工具
|
在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved |
京公网安备 11010802041100号
|
京ICP备19059560号-4
| PHP1.CN 第一PHP社区 版权所有