查看原文
其他

Web开发性能工具

w3cplus 计算机与网络安全 2022-06-01

信息安全公益宣传,信息安全知识启蒙。

加微信群回复公众号:微信群;QQ群:16004488

加微信群或QQ群可免费索取:学习教程


得益于大量的 Grunt 和 Gulp 插件,我们可以轻松实现网站数据的可视化,虽然深入理解这些工具还比较困难,但分门别类的将它们列出来,也是很有帮助的。


内容分发网络(CDN)


CDN 可以帮你把网站的资源分发到世界各地,有助于提高网站的响应速度,当然,这对于那些特殊地区的用户是收效甚微的。


CloudFlare


CloudFlare 的强大之处在于它可以成为你的 DNS 服务器(CDN 只是它所有服务的一个组成部分),这样对你的网站发起的所有请求都会经过它。


CloudFlare 的 CDN 在过去十五年的设计和发展中,并没有一味的守旧和固步自封。我们的专利技术中充分利用了最新的技术进步,包括并不限于硬件、web 服务器和网络路由。换言之,我们创新的建设了下一代的 CDN。新的 CDN 配置简单、价格低廉,其性能也一定比你使用过的任何传统 CDN 都要优秀。


MaxCDN


CSS-Tricks 当前就在使用 MaxCDN 托管所有的静态资源。它可以无缝地融合 WordPres 和 W3 的所有缓存资源,所以我们无需做什么特别处理,即可将资源移入 CDN,并能保证链接的准确性。




对于一个博客来说,考虑到其中的大文件主要是 JavaScript、CSS 和图片,而不是视频等类型,这贷款占用的可真多。


我们的 CDN 服务同样是一个网站加速器和实时控制中心。创建它,就是为了让网站的用户和运维都能从下一代 CDN 中获得最大收益。


CloudFront


亚马逊网络服务(AWS)版本的 CDN。


亚马逊 CloudFront 是一个内容分发网络服务。它可以无缝融合入其他的亚马逊网络服务产品,为开发者和企业分发内容到最终用户手中提供了一种简单的方式,整个过程都具有低延迟、高转换速度的特点,也没有最小使用量的强制要求。


CDNperf


上述的 CDNs 并不能托管你任意的资源,它们往往只是托管最频繁用到的文件。虽然对于线上产品来说将资源和服务器托管到私有的 CDN 上并不是最好的方式,但这种方式对于分发资源来说仍然是快速和简单的。


CDNperf 可以帮你找出最快和最可信赖的 JavaScript CDNS,让你的网站更快更有朝气。



性能测试


下面的这些性能测试工具,使用了量化的方式测试了网站中诸如首字节加载时间(time to first byte)或者渲染时间等表现。有些工具还会检查特别检查资源是否被缓存,多个 CSS 或 JS 文件是否值得合并。


WebPagetest


WebPagetest 是性能测试的黄金标准,它提供了多方面的量化指标用于性能测试,比如有一个基本的评分,用于评价当前页面优化的水平;有一个截图,显示页面加载后的视觉效果;还有一个浏览器加载资源的瀑布流…


根据用户浏览器真实的连接速度,在全球范围内进行网页速度测试,并提供详细的优化建议。



通过使用 API wrapper,也可以将 WebPagetest 的相关服务添加到 NPM 模块和命令行工具中。


webpagetest-mapper:将 WebPageTest 的测试数据转换为可读的文档格式。

WPT Bulk Tester:使用 Google Docs 测试多个 URLs(如果你拥有 API key,也可以使用 webpagetest.org 来做这件事,或者其他公开可访问的实例)。


Yslow


Yslow 基于 Yahoo 的高性能网页教条,分析网页的性能并给出响应缓慢的原因。


Google PageSpeed


PageSpeed 根据网页最佳实践分析和优化测试的网页。



PageSpeed 也有一个 CLI(Command Line Interface)工具:PSI(PageSpeed Insights with reporting)


在构建进程中,可以使用 PSI 测试移动端和桌面端的性能,最终得到可读性良好的测试结果。



我的网站都开销到哪里去了?


评估网站在世界各地为每个移动端用户支出的维护成本。



Pingdom 网站速度测试


输入 URL 地址,即可测试页面加载速度,分析并找出性能瓶颈。



SpeedCurve


SpeedCurve 既可以让你追踪竞争对手的性能表现,也可以追踪自己的性能表现。使用 SpeedCurve 时,你可以查看某个因素在不同站点的速度表现。对于移动用户来说,他们希望网站在手机上加载起来要快于电脑,如果感到加载迟缓,往往会迅速关上网页,所以,网站的响应速度对他们很重要。



Calibre


Calibre 可以帮你追踪页面的加载时间,以及页面大小。问题页面(Janky page)?是的,Calibre 会直接告诉你哪些页面有问题。



GT Metrix


GT Metrix 结合了 Google PageSpeed 和 YSlow,帮助开发者创建快速、高效和全面优化的网页浏览体验。



perf.js


在开发过程中,将性能的时序情况显示在页面上。


perf bar


一种简单的方式,用于快速收集和查看网页性能,提供预置的量化标准,也支持自定义的量化标准。


grunt-perfbudget


用于评估性能的 Grunt task。 grunt-perfbudget 使用 WebPagetest 的公有或私有实例在特定的 URL 进行测试。它会将测试结果和你预期的性能期望做比较,如果小于预期,那么这个 task 就顺利完成了,如果超过了你预期的性能期望,那么就会报告失败,并且会帮助你分析超出预期的原因。


Sitespeed


Sitespeed.io 是一个基于最佳实践以及一些加载时序等量化标准的开源工具,有助于开发者分析网页的加载速度和渲染性能。它会从开发者的站点收集多个页面的数据,根据最佳实践等规则来分析这些网页,并将结果以 HTML 的形式输出,或者以数值的形式发送到 Graphite。


speedgun


该网站允许你使用 Speedgun.js 收集任意公开站点的性能数据。它会运行五次,并显示一个友好的示图,帮助开发者了解当前页面的加载过程。


gulp size


显示项目大小。



浏览器工具盒插件


Chrome 开发者工具


在 Chrome 的开发者工具中,对于评估性能有两个非常有用的标签:Audits 和 Network。


Audit 面板用于分析加载的页面。它可以提供优化建议,减少页面加载时间,加快页面的响应速度。



Network 面板以动态的方式实时地展示了资源的请求和下载。虽然辨析和定位这些请求会比纯粹的加载页面多花一些时间,但这些消耗对于指导页面的性能优化是非常重要的。



火狐开发者浏览器


该浏览器是为开发者而创造的,专注于服务开发者的工作流。这是有史以来第一次,将构建、测试和扩展等服务集中于一体。


更多信息请查看 MDN 上的 Network Monitor。


Page performance


这个扩展插件应用于 Chrome 浏览器,可以开速分析当前页面的性能。如果浏览器打开了多个标签,那么该插件会自动分析当前页面的性能表现。



审查


PerfAudit


我们审查页面的加载和渲染性能。对于令人反感的响应缓慢和问题页面,我们有义不容辞的使命提供快速、稳定和准确的页面。


Perfmonkey


PerfMonkey 让追踪页面的渲染性能变得无比简单。


SVG 和图片


ImageOptim


ImageOptim 是一个免费的应用,它在减少图片体积、提高加载速度的同时,还不会牺牲图片质量。它优化了压缩参数、移除了无用的头信息和非必要的颜色配置信息。



它也可以被集成到 Grunt 和 Gulp 中。


SVGO


SVG Optimizer 是一个基于 Nodejs 的 SVG 矢量图形优化工具。


如果你需要的是交互界面的操作,而不是 CLI,那么可以下载这个 APP。


SVGOMG


SVGOMG 是 SVGO’s Missing GUI 的缩写,旨在揭露 SVG 文件的主要问题,而不具有 SVGO 的完整可配置项。



手动优化 SVGs


类似于其他的图形文件,SVG 也应该在上线前被优化。虽然有许多类似 Raymond 的工具可以帮你做这种优化,但最好的方式还是深入理解其细节并做一些手动的优化。


Triamge


Triamge 是一个扩平台的 GUI 和 CLI 工具,用于优化网站的图片文件。它组合使用 optipng、pngcrush、advpng 和 jpegoptim,并根据文件类型做优化(最新版本中,已经支持 PNG 和 JPG)。



CSS


CSS Triggers


该网站用于展示哪些 CSS 属性可以影响浏览器的布局、渲染和其他组合操作。



更多有关 CSS-triggers 的消息,可以点击这里查看。


CSS Stats


该网页应用以可视化的形式展示了开发者项目中有关 CSS 的统计信息。



CSS Shrink


CSS 压缩工具。由于 CSS 是页面渲染的核心文件,所以必须保持轻巧,便于快速响应和渲染。


uncss


UnCSS 是一个用于移除脚本中无用 CSS 的工具。它可以审查多个文件,也可以审查由 JavaScript 注入的 CSS。


它也可以被集成到 Grunt 和 Gulp 中。


Critical path


提取和整合 HTML 中关键的 CSS。


HTML


HTMLMinifier


HTMLMinifier 是一个高度可配置、经过完善的测试、基于 JavaScript 的 HTML 压缩工具,并且内置了代码审查类的工具。


gulp-htmlmin


用于压缩 HTML 的 gulp 插件。


grunt-contrib-htmlmin


用于压缩 HTML 的 grunt 插件。


JavaScript


uglifyjs


JavaScript 解析器、混淆、压缩和美化工具集。


它也可以被集成到 Grunt 和 Gulp 中。


你也许并不需要某些 jQuery 插件


jQuery 及其附属工具都是非常优秀的项目,使用它们往往使开发工作轻松而又快捷。


另一方面,如果你正在开发一个库,那么你需要思考一下是否真的需要依赖于 jQuery。也许你只需要引入几行代码,就可以放弃引入一个库实现某些功能。如果你的库只是针对于高级浏览器,那么可能直接调用浏览器的内置函数就可以实现相关功能了。



扩展阅读

  • Usertiming API

  • Jank Free

  • Scrolling performance

  • Mobile web performance auditing

  • Gone in 60 frames per second

  • Udacity course on rendering performance


▼ 点击阅读原文,查看更多精彩文章。

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存