- 工信部备案号 滇ICP备05000110号-1
- 滇公安备案 滇53010302000111
- 增值电信业务经营许可证 B1.B2-20181647、滇B1.B2-20190004
- 云南互联网协会理事单位
- 安全联盟认证网站身份V标记
- 域名注册服务机构许可:滇D3-20230001
- 代理域名注册服务机构:新网数码
网上有很多类似压缩html代码的,可是找了许多,代码的确是可以压缩,但是就只留一个代码?喵喵喵???怎么实际的用都不说明一下
然后我结合我自己的代码修改了一下,首先网上都是提供的一个函数,那么首先得获取php生成的代码呀
然后就可以使用
ob_start();//打开缓冲区
然后在使用
ob_get_clean();//获取缓冲区并且清除
这样就得到了网站生成的html代码
然后就可以进行代码压缩
$content = "html内容";
$output = ltrim(rtrim(preg_replace(array("/> *([^ ]*) *[ ]+\\1<'],$content)));
这样就可以压缩代码了!可是这并没有完,我把这些代码用到网站里面的时候,压缩没问题,可是到了有代码显示(及pre标签)的页面,显示的pre标签里面的代码全部变成一行了?什么鬼....
然后找了半天最后发现....是代码压缩的锅..然后pre标签本身是按照编辑器回车来确定换行的,所以html源码里面也会有换行,那么咋办呢
当然就是在压缩html代码的时候不要去压缩pre标签咯
然后我选择用正则先提取出来pre标签,然后压缩完成后在进行还原代码
所以最终的代码
$data = [];//存放pre标签内容
$i = 0;//pre标签下标
htmlFilterPreCompress($data,$content,$i);
function htmlFilterPreCompress($data,$content,$index){
$pre = "/<pre[\s\S]*?/";
if(preg_match($pre,$content,$m)){
//替换
$content = str_replace(current($m),"[HTML_COMPRESS]{$index}[/HTML_COMPRESS]",$content);
$data[$index] = current($m);
$index++;
//递归再次去检测一次
$this->htmlFilterPreCompress($data,$content,$index);
}else{
$output = ltrim(rtrim(preg_replace(array("/> *([^ ]*) *[ ]+\\1$val){
$output = str_replace("[HTML_COMPRESS]{$key}[/HTML_COMPRESS]",$val,$output);
}
echo $output;
}
}
恩,代码就是这样的
售前咨询
售后咨询
备案咨询
二维码
TOP