首页
技术博客
PHP教程
数据库技术
前端开发
HTML5
Nginx
php论坛
新用户注册
|
会员登录
PHP教程
技术博客
编程问答
PNG素材
编程语言
前端技术
Android
PHP教程
HTML5教程
数据库
Linux技术
Nginx技术
PHP安全
WebSerer
职场攻略
JavaScript
开放平台
业界资讯
大话程序猿
登录
极速注册
取消
热门标签 | HotTags
nodejs
join
cpython
range
tree
solr
bitmap
sum
go
spring
merge
filter
future
controller
actionscrip
byte
text
node.js
expression
string
list
数组
version
usb
tags
rsa
python3
php
hook
object
heatmap
format
dagger
dockerfile
config
bytecode
php5
callback
bit
erlang
replace
cPlusPlus
python2
get
express
python
buffer
runtime
jsp
random
integer
hash
fetch
php8
include
triggers
flutter
substring
scala
header
default
settings
less
subset
case
process
java
testing
yaml
iostream
copy
metadata
hashset
main
stream
post
request
web
plugins
当前位置:
开发笔记
>
编程语言
> 正文
测试关注指标记录点
作者:洱冬橙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
写下你的评论吧 !
吐个槽吧,看都看了
会员登录
|
用户注册
推荐阅读
php
OkHttp3的基本使用及其特性
本文介绍了OkHttp3的基本使用和特性,包括支持HTTP/2、连接池、GZIP压缩、缓存等功能。同时还提到了OkHttp3的适用平台和源码阅读计划。文章还介绍了OkHttp3的请求/响应API的设计和使用方式,包括阻塞式的同步请求和带回调的异步请求。 ...
[详细]
蜡笔小新 2023-12-10 22:46:04
php
ABAP开发发送邮件程序的配置和代码整理
本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ...
[详细]
蜡笔小新 2023-12-13 15:50:17
php
Python中字符串的压缩与解压缩方法及应用
本文介绍了在Python中使用zlib模块进行字符串的压缩与解压缩的方法,并探讨了其在内存优化方面的应用。通过压缩存储URL等长字符串,可以大大降低内存消耗,虽然处理时间会增加,但是整体效果显著。同时,给出了参考链接,供进一步学习和应用。 ...
[详细]
蜡笔小新 2023-12-11 17:42:43
php
Alink回归预测的不完善问题及期待
本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ...
[详细]
蜡笔小新 2023-12-14 14:25:33
php
Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ...
[详细]
蜡笔小新 2023-12-14 12:01:13
php
知识图谱——机器大脑中的知识库
本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ...
[详细]
蜡笔小新 2023-12-14 10:06:19
php
《数据结构》学习笔记3——串匹配算法性能评估
本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ...
[详细]
蜡笔小新 2023-12-13 16:16:05
php
深入理解CSS中的margin属性及其应用场景
本文主要介绍了CSS中的margin属性及其应用场景,包括垂直外边距合并、padding的使用时机、行内替换元素与费替换元素的区别、margin的基线、盒子的物理大小、显示大小、逻辑大小等知识点。通过深入理解这些概念,读者可以更好地掌握margin的用法和原理。同时,文中提供了一些相关的文档和规范供读者参考。 ...
[详细]
蜡笔小新 2023-12-12 18:01:10
object
Redis底层数据结构之压缩列表的介绍及实现原理
本文介绍了Redis底层数据结构之压缩列表的概念、实现原理以及使用场景。压缩列表是Redis为了节约内存而开发的一种顺序数据结构,由特殊编码的连续内存块组成。文章详细解释了压缩列表的构成和各个属性的含义,以及如何通过指针来计算表尾节点的地址。压缩列表适用于列表键和哈希键中只包含少量小整数值和短字符串的情况。通过使用压缩列表,可以有效减少内存占用,提升Redis的性能。 ...
[详细]
蜡笔小新 2023-12-12 16:06:05
php
django视图函数的使用方法
本文介绍了django中视图函数的使用方法,包括如何接收Web请求并返回Web响应,以及如何处理GET请求和POST请求。同时还介绍了urls.py和views.py文件的配置方式。 ...
[详细]
蜡笔小新 2023-12-12 16:02:59
php
lua语言闭包、模式匹配、日期、编译、模块的特性及应用
本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ...
[详细]
蜡笔小新 2023-12-14 18:18:21
php
基于layUI的图片上传前预览功能的2种实现方式
本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ...
[详细]
蜡笔小新 2023-12-14 17:06:58
php
Java实现大数乘法(分治算法)
本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ...
[详细]
蜡笔小新 2023-12-14 15:43:50
php
HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ...
[详细]
蜡笔小新 2023-12-14 15:08:18
php
利用中间件模式简化代码逻辑
在编写业务代码时,常常会遇到复杂的业务逻辑导致代码冗长混乱的情况。为了解决这个问题,可以利用中间件模式来简化代码逻辑。中间件模式可以帮助我们更好地设计架构和代码,提高代码质量。本文介绍了中间件模式的基本概念和用法。 ...
[详细]
蜡笔小新 2023-12-12 15:08:23
洱冬橙66_156
这个家伙很懒,什么也没留下!
Tags | 热门标签
nodejs
join
cpython
range
tree
solr
bitmap
sum
go
spring
merge
filter
future
controller
actionscrip
byte
text
node.js
expression
string
list
数组
version
usb
tags
rsa
python3
php
hook
object
RankList | 热门文章
1
java问题解读,String类为什么是final的
2
coredata 数据库升级
3
第四章 Shell流程控制
4
Java如何将ArrayList写入文件,然后将该文件读取(加载)到原始ArrayList?
5
unigine lookAt
6
如何在 R 中复制绘图
7
centos php部署到nginx 404_NodeJS项目部署到阿里云ECS服务器全程详解
8
phpstorm中项目之间快速切换
9
Angular - 循环遍历子指令中的表单元素 - Angular - loop over form elements that are in a child directive
10
C#使用七牛云存储上传下载文件
11
java布尔字段用is前缀_POJO类中布尔类型的变量都不要加is前缀详解
12
白话 贝叶斯公式_白话贝叶斯,通过实例了解贝叶斯的魅力
13
reg封装
14
第二轮冲刺第三天
15
JDK8新特性详细介绍[java入门]
PHP1.CN | 中国最专业的PHP中文社区 |
DevBox开发工具箱
|
json解析格式化
|
PHP资讯
|
PHP教程
|
数据库技术
|
服务器技术
|
前端开发技术
|
PHP框架
|
开发工具
|
在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved |
京公网安备 11010802041100号
|
京ICP备19059560号-4
| PHP1.CN 第一PHP社区 版权所有