在没有使用vue angular react 三大流行框架去开发静态的项目时,困扰我们最多的就是缓存问题,没有三大框架的优势之热刷新功能,如何做到我们修改了我们引用的外部文件里的某些内容,回到页面,刷新一下就能看到最新的效果或是样式呢?说的直白点就是动态的给文件加版本号,在没有接触php我是不知道如何用js去控制,为了安全,前端不具有改写文件的能力,我就想到了同样可以嵌套html内容的php语言,作为一个前端,懂点后端语言真的没坏事,不说废话了,上代码.
第一步:项目下面一定得有一个 控制版本的php文件,version.php,内容如下:
1 <?php 2 /** 3 * 4 * @authors shufei 5 * @date 2018-06-17 12:15:27 6 * @version $ver strtotime(date('Y-m-d H:i:s')) 7 */ 8 function AutoVersion( $file ) { 9 $ver = strtotime(date('Y-m-d H:i:s')) ; 10 echo $file .'?t=' .$ver; 11 }
这个 AutoVersion 方法需要一个参数也是文件的file路径 $file,版本号 $ver 赋值为实时的时间戳,当你项目的部分开发完成后可以设置 $ver为固定的一个值
第二步:将开发的html页面改为php页面,index.php
1 <?php require_once "version.php";?> 2 <!DOCTYPE html> 3 <html> 4 <head> 5 <meta charset="utf-8"> 6 <meta http-equiv="X-UA-Compatible" content="IE=edge"> 7 <meta name="viewport" content="width=device-width, initial-scale=1"> 8 <meta name="Generator" content="EditPlus®"> 9 <meta name="Author" content=""> 10 <meta name="Keywords" content=""> 11 <meta name="Description" content=""> 12 <title>Document</title> 13 <link href="<?php AutoVersion('test.css'); ?>" rel="stylesheet" type="text/css" > 14 <script src="<?php AutoVersion('test.js'); ?>"></script> 15 </link> 16 </head> 17 <body> 18 <h1>Hello,world!</h1> 19 </body> 20 </html>
<?php require_once "version.php";?>表示依赖 version.php文件,因此 <?php AutoVersion('test.css'); ?>和<?php AutoVersion('test.js'); ?>都会被替换成原有的文件路径
加版本号,如果 version.php 里的$ver是实时时间戳,那么test.js 或者 test.css文件里有任何修改,刷新一下都是最新的,没有缓存顾虑,再也不用手动的去耗时耗力的操作每个文件夹了
如果你还想要热刷新那种差不多的功能,哪就在你的开发页面index.php里head里加上 <meta http-equiv="refresh" content="3"> ,页面3秒自动刷新一次,同时文件也是最新的,css或js里的代码
一旦被修改页面自动刷新展示最新的页面和效果,缺点嘛,你懂得,就是需要看dom结构,3秒一刷新,控制台element里看dom结构就重置了,是不是心想算了,还是不偷懒了,自己手动刷新一次又怎么了,不影响你
的美丽动容
个人摸索出来的方法,没有接触PHP,如有问题请留言