搜索
首页web前端css教程快速吞噬缓存破坏

快速吞噬缓存破坏

为了获得最佳的网络性能,为CSS,JavaScript,Image和Fonts等资产实施强大的缓存策略至关重要。这使浏览器可以保留这些文件,从而在网站内重新访问或导航时大大加速页面加载时间。但是,更新这些资产需要一种迫使浏览器下载新版本的方法。尽管存在几种技术,但本文详细介绍了一种使用Gulp的最新方法。

利用查询字符串修改缓存破坏

与较早的信念相反,修改查询字符串仍然是缓存破坏的有效方法,尤其是在诸如CloudFlare减轻潜在边缘案例之类的服务中。

最初,您的HTML可能包括这样的资产链接:

<link href="style.css?v=1" rel="stylesheet">

随后,要强制缓存刷新,只需更改查询字符串值:

<link href="style.css?v=2" rel="stylesheet">

HTML本身通常具有较短的缓存持续时间或没有缓存,从而确保了HTML更改的立即可见性。

手动与自动缓存破坏

以前,手动缓存破坏涉及直接修改PHP变量:

  <link href="style.css?v=<?php%20echo%20%24ver;%20?>" rel="stylesheet"><link href="some-other-asset.css?v=<?php%20echo%20%24ver;%20?>" rel="stylesheet">

这种方法虽然功能性,但很容易受到监督,而且通常很麻烦。

与湾和毛replapply自动化

采用基于毛的构建过程,该过程处理诸如SASS汇编,Babel Transpilation和File Concatenation之类的任务允许自动加速拆卸。 gulp-replace插件简化了此过程。

可以创建一个Gulp任务,以搜索标头文件中的特定字符串(例如, cache_bust= ),并用动态生成的基于时间戳的字符串替换它:

 gulp.task(“ CACH-BUST-CSS”,function(){
  var cbString = new Date()。getTime();
  返回Gulp
    .src([“ header.php”])
    。管道(
      替换( /cache_bust = \ d /g,function(){
        返回“ cache_bust =” cbString;
      }))
    )
    .pipe(gulp.dest(“。”));
});

可以针对JavaScript文件实现类似的任务。

优化效率

当前的实现每当任何资产更改时,都会更新所有CSS资产的查询字符串。一种更有效的方法将仅针对修改的文件。该优化计划用于将来实施。

这种基于毛的策略只是一种方法。其他Gulp插件和构建系统提供替代方法。该解决方案有效地解决了该项目的特定需求。随时分享您喜欢的缓存技术!

以上是快速吞噬缓存破坏的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
@KeyFrames vs CSS过渡:有什么区别?@KeyFrames vs CSS过渡:有什么区别?May 14, 2025 am 12:01 AM

@keyframesandCSSTransitionsdifferincomplexity:@keyframesallowsfordetailedanimationsequences,whileCSSTransitionshandlesimplestatechanges.UseCSSTransitionsforhovereffectslikebuttoncolorchanges,and@keyframesforintricateanimationslikerotatingspinners.

使用页面CMS进行静态站点内容管理使用页面CMS进行静态站点内容管理May 13, 2025 am 09:24 AM

我知道,我知道:有大量的内容管理系统选项可用,而我进行了几个测试,但实际上没有一个是一个,y&#039;知道吗?怪异的定价模型,艰难的自定义,有些甚至最终成为整个&

链接HTML中CSS文件的最终指南链接HTML中CSS文件的最终指南May 13, 2025 am 12:02 AM

链接CSS文件到HTML可以通过在HTML的部分使用元素实现。1)使用标签链接本地CSS文件。2)多个CSS文件可通过添加多个标签实现。3)外部CSS文件使用绝对URL链接,如。4)确保正确使用文件路径和CSS文件加载顺序,优化性能可使用CSS预处理器合并文件。

CSS Flexbox与网格:全面评论CSS Flexbox与网格:全面评论May 12, 2025 am 12:01 AM

选择Flexbox还是Grid取决于布局需求:1)Flexbox适用于一维布局,如导航栏;2)Grid适合二维布局,如杂志式布局。两者在项目中可结合使用,提升布局效果。

如何包括CSS文件:方法和最佳实践如何包括CSS文件:方法和最佳实践May 11, 2025 am 12:02 AM

包含CSS文件的最佳方法是使用标签在HTML的部分引入外部CSS文件。1.使用标签引入外部CSS文件,如。2.对于小型调整,可以使用内联CSS,但应谨慎使用。3.大型项目可使用CSS预处理器如Sass或Less,通过@import导入其他CSS文件。4.为了性能,应合并CSS文件并使用CDN,同时使用工具如CSSNano进行压缩。

Flexbox vs Grid:我应该学习两者吗?Flexbox vs Grid:我应该学习两者吗?May 10, 2025 am 12:01 AM

是的,youshouldlearnbothflexboxandgrid.1)flexboxisidealforone-demensional,flexiblelayoutslikenavigationmenus.2)gridexcelstcelsintwo-dimensional,confffferDesignssignssuchasmagagazineLayouts.3)blosebothenHancesSunHanceSlineHancesLayOutflexibilitibilitibilitibilitibilityAnderibilitibilityAndresponScormentilial anderingStruction

轨道力学(或我如何优化CSS KeyFrames动画)轨道力学(或我如何优化CSS KeyFrames动画)May 09, 2025 am 09:57 AM

重构自己的代码看起来是什么样的?约翰·瑞亚(John Rhea)挑选了他写的一个旧的CSS动画,并介绍了优化它的思维过程。

CSS动画:很难创建它们吗?CSS动画:很难创建它们吗?May 09, 2025 am 12:03 AM

CSSanimationsarenotinherentlyhardbutrequirepracticeandunderstandingofCSSpropertiesandtimingfunctions.1)Startwithsimpleanimationslikescalingabuttononhoverusingkeyframes.2)Useeasingfunctionslikecubic-bezierfornaturaleffects,suchasabounceanimation.3)For

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用