前端如何实现网络速度测试功能_分析Web前端测试要点,从架构原理上进行分析,希望大家能够掌握...

基于Web前端分析过程,大概有十几个测试要点,我们今天主要来讲解结合前五个要点进行详细解说。前端测试点主要针对前端展开,什么叫前端分析呢?就是我们所有的分析和测试要点所站的视角都是针对客户端或者浏览器来对系统进行分析和测试的,我们不需要考虑服务器端的架构是什么样的,也不需要考虑从服务器角度来说要去关注数据库、服务器、系统集成、Web服务器的配置等,这十几个测试要点可以测试任何的类型网站的质量,我们不需要关注后台的相关内容,例如:我们可以使用些这些测试要点去测试任何的网站质量怎么样,我们是从前端的视角来检验系统的质量,除了这些要点之外,所有WEB网站的工作原理都需要理解,因为所有的内容都是基于网络协议展开的,首先,我们得了解HTTP协议的工作原理过程,才能够对这些测试要点进行全面的分析和理解,才能够真正的结合实践应用。其次,要对浏览器工作原理进行深入了解,我们一定要对浏览器和服务器是如何工作的原理有一个深入的了解,前面我们也通过网络架构原理课程了解了相关的过程,包括软件兼容性内容中与大家详细讲解了浏览器的工作原理及页面的渲染引擎做了很详细的讲解,让大家全面的理解基于前端的测试要点。

38edda87e8fb9fc4debecfc270355d2e.png

尽可能减少HTTP请求的数量。我们可以通过合并的方式,例如:可以将JS、CSS或者图片合并到一个页面中,可以采用多个图片合并到一个图片中,这样就能达到减少HTTP请求的数量,减少HTTP请求的目的是为了减少HTTP释放链接的资源,提升系统访问速度,从而提升性能。

前端浏览器缓存应用

大家都知道浏览器都会把我们访问过网站的这些静态资源保存在硬盘的目录中,下次去访问同样的资源,服务器会检测硬盘中是否存在缓存记录,如果已经保存了资源就直接读取,达到减少请求数据的目的,可以提升系统的性能,所以请大家好好利用浏览器的缓存机制,当然缓存机制也存在它的一些弊端,如果浏览器缓存设置时间过长,如果我们更新了内容之后,浏览器客户端也不知道,因为浏览还是会使用之前缓存起来的内容,例如:大家平时在工作中经常遇到这种问题,就是系统重新部署发布之后,我们再次访问系统为什么发现功能并没有更新,这其实就是利用了浏览器的缓存机制,再把缓存清空重新刷新一下就能看到最近修改的相关功能。

0b84987a267bc455061358cf8bded20d.png

利用Gzip压缩机制:只针对文本类资源有效。

什么是文本类资源?

例如:基于前端页面的一些JS脚本、CSS、HTML这些都属于文本内容。文本类资源压缩比例可以达到70%以上,基本上100K的资源可以被压缩成20K,这是一个非常高的压缩比例。

为什么只针对文本类资源压缩有效?因为像我们在网站上看到的图片都是已经被压缩过了,例如:PNG、GIF、JPEG他们都是已经被压缩过了,即使再有Gzip压缩也没有任何作用,大家可以拿一张PNG的图片,然后使用winrar软件对这张图片进行压缩,你会看到压缩图片的大小不会有变化,因为已经进行了压缩不能再压缩了,压缩前和压缩后的图片大小基本是一致的。因为压缩资料后,在网络传输的时候过程可以节省很多的带宽资源,而我们的网站除了图片以外,文本也占去绝大部分篇幅,从而达到提升页面访问的速度,提升系统性能。

9b8543a5bf893d1280afc7e55272d726.png

把CSS文件放在HTML的开头

我们知道CSS文件主要用来渲染、排版的,我们前面了解了浏览器的渲染过程,系统如果发现网站存在静态资源后,然后下载保存到硬盘中,便于我们访问网站渲染的过程中能够使用,我们尽可能的将CSS放在最开始的地方,让浏览一开始就能把这个资源下载完成,这样后面渲染的过程才会进展得更加顺利,不会因为中途出现静态资源再保存非常浪费时间,请务必将所以的CSS压缩到一个文件中,

9b9a26a05f510b93465a9c9c2a9c47a3.png

将JavaScript文件放在HTML的结尾.

JS其实不是用来做渲染的,而是当我们的页面渲染完成以后,用户在操作页面功能的过程中能够达到一种动态的效果,JS既然没有这种渲染的效果,我们将JS放在最后让浏览器渲染完成页面最后等浏览器渲染页面完成后,用户才可以调用到JS来进行动态的操作与文件处理,放在最开始的地方浏览器会优先下载JS,会延迟下载图片等文本相关内容,会影响页面的性能,页面渲染显示的内容更缓慢。

5e5336b2d21d4afa328dba5bcbbd51ab.gif

总结:以上五点前端分析测试要求都是基于前端原理过程梳理出来的核心内容,很多同学在企业中做测试一般都是基于UI界面的功能测试,很少从原理上去深入理解系统,于是会感觉基于前端页面的测试很简单,但是要想达到高级测试工程师的要求,必须要学会从原理的内部过程中来理解事物,从事物的起源中理解内容,才会让我们的知识面更具内涵,肤浅的内容没有竞争力,希望大家能够掌握。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/340557.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

将Websocket与Spring Framework和Vuejs结合使用

Websocket是客户端和服务器之间的全双工(持久)连接,因此两者可以彼此共享信息,而无需重复建立新的连接。 这消除了从客户端重复轮询以从服务器获取更新的需要。 并非所有浏览器都支持Websocket,因此我们利用SockJS ja…

python函数和模块的使用方法_Python学习06_函数和模块的使用

引入在写有些代码的时候,会发现有些步骤重复了多次,他也不像循环,都是相同的东西在重复,而是指做某件事情的步骤方法,做事的人或对象发生了改变,但是方法却没有改变。要想写出高质量的代码,首先…

tmemo 选择消除行_Divi模块,行和部分加入高级动画选项

一切元素的动画选项每个Divi模块,行和部分都带有高级动画选项,你可以使用这些选项来吸引访问者并使页面更加耀眼。Divi引入一个全新的动画系统,并将这些高级动画选项扩展到每个Divi模块,行和部分!这些新选项已合并到一…

java8 streams_Java 8 Friday:使用Streams API时的10个细微错误

java8 streams在Data Geekery ,我们喜欢Java。 而且,由于我们真的很喜欢jOOQ的流畅的API和查询DSL ,我们对Java 8将为我们的生态系统带来什么感到非常兴奋。 Java 8星期五 每个星期五,我们都会向您展示一些不错的教程风格的Java …

python带参数装饰器 函数名_python 全栈开发,Day11(函数名应用,闭包,装饰器初识,带参数以及带返回值的装饰器)...

一、函数名应用函数名是什么?函数名是函数的名字,本质:变量,特殊的变量。函数名(),执行此函数。python 规范写法1. #后面加一个空格,再写内容,就没有波浪线了。2.一行代码写完,下面一…

python逐行写入excel_快来看看Python如何玩转Excel

来源:ID(innerV)如何用Python来操作Excel文件呢?首先,使用pip 包管理器来安装两个包,安装命令:pip install xlrd pip install xlwt我们来看读取excel的例子,第1行,import 导入xlrd包第4行&#…

Java面试准备:15个Java面试问题

并非所有的访谈都将重点放在算法和数据结构上—通常,访谈通常只侧重于您声称是专家的语言或技术。在此类访谈中,通常没有任何“陷阱”问题,而是它们要求您利用内存和使用该语言的经验–换句话说,它们测试您对编程语言的了解。 但…

mysql排插问题_MySQL一次数据插入故障记录

某天突然收到报警,数据库大量事务等待,进到数据库后发线大量的插入操作被阻塞,且都是同一个表的。通过 show engine innodb status 发现插入操作都是在等待索引 idx_create_time(create_time) 的 insert intention lock(跟 gap 锁互斥)&#…

纯净pe工具_微PE工具箱2.0

(特殊时期,在家时间多一些,突然想到多年的公众号,重启试试,嗯就先每一天推荐一个软件吧)微PE工具箱(WinPE)是一款非常好用的PE系统(独立的预安装环境),非常纯净,是装机维护得力的助手。安装简单&#xff0c…

sping jdbc 链接mysql_Spring Boot JDBC 连接数据库示例

文本将对在spring Boot构建的Web应用中,基于MySQL数据库的几种数据库连接方式进行介绍。包括JDBC、JPA、MyBatis、多数据源和事务。JDBC 连接数据库1、属性配置文件(application.properties)spring.datasource.urljdbc:mysql://localhost:3306/testspring.datasourc…

二分查找递归与非递归的时间比较_我们说一说Python的查找算法!

相信大家在面试开发岗和算法岗时,评委最喜欢问的就是:您能给我说一下查找和排序算法有哪些?今天咱们就说一说Python中最常用的查找算法,下期我们再推出排序算法。首先要明白查找是查什么?我们希望能给定一个值&#xf…

jsf 自定义属性_如何在JSF中实现自定义密码强度指示器

jsf 自定义属性使用JavaScript验证密码强度是一项常见任务。 在本文中,我将展示如何向基于JSF的Web应用程序添加密码强度指示器。 的 PrimeFaces中的密码组件已经具有密码强度的反馈指示符,但是它有两个主要缺点: 反馈指示器没有响应&#…

OAuth 2.0 Java指南:5分钟保护您的应用程序安全

使用Okta的身份管理平台轻松部署您的应用程序 使用Okta的API在几分钟之内即可对任何应用程序中的用户进行身份验证,管理和保护。 今天尝试Okta。 现代应用程序依赖于用户身份验证,但是它可能给Java开发人员带来困难的挑战,以及一系列特定于框…

flutter从0到1构建大前端应用 pdf_前端骨架屏都是如何生成的

作者:SHERlocked93转发链接:https://mp.weixin.qq.com/s/j2XzwLPnalDCNaKkfjH-0Q前言相比于早些年前后端代码紧密耦合、后端工程师还得写前端代码的时代,如今已发展到前后端分离,这种开发方式大大提升了前后端项目的可维护性与开发…

成为Java流大师–第1部分:创建流

在许多情况下,声明性代码(例如,具有Streams的功能组合)可提供出色的代码指标。 通过本动手实验文章系列进行编码,并成为Java Streams的主教练,从而成为一名更好的Java程序员。 Streams的整个想法是代表一个…

java 6 基础教程_Java小白入门教程(6)——循环语句

提纲:1、循环结构2、while循环3、do-while循环4、for循环5、break语句6、continue语句7、循环嵌套8、作业一、循环结构1.1 概念条件满足,某些代码会被反复多次的执行。条件不成立了,循环结束。0-n次。1.2 为什么使用循环开发中可能会把某些代…

事件触发控制_SystemVerilog线程控制与通信

01线程控制1.概述线程,即独立运行的程序;线程需要被触发执行,可以结束或者不结束;在module中的initial和always,都可以看作独立的线程,他们在仿真0时刻开始,而选择结束或者不结束;在…

java必读书籍_最佳5本Java性能调优书籍–精选,必读

java必读书籍为什么Java开发人员应该阅读有关性能调优的书? 当我很久以前第一次面对这个问题时,我以为以后会做,但是我很长一段时间都没有回过头来。 仅当我在用Java编写的任务关键型服务器端财务应用程序中遇到严重的性能和可伸缩性问题时&a…

成为Java流大师–第4部分:数据库流

SQL一直是一种声明性语言,而Java长期以来势在必行。 Java流改变了游戏规则。 通过本动手文章编写您的方式,并学习如何使用Java流对RDBMS数据库执行声明性查询,而无需编写任何SQL代码。 您会发现,Java流和SQL命令的动词之间有着惊人…

unsafehelper java_Java 9中将移除 Sun.misc.Unsafe

灾难将至,Java 9中将移除 Sun.misc.UnsafeOracle 正在计划在Java 9中去掉 sun.misc.Unsafe API。 这绝对将是一场灾难,有可能会彻底破坏整个 java 生态圈。 几乎每个使用 java开发的工具、软件基础设施、高性能开发库都在底层使用了 sun.misc.Unsafe。 下…