wordpress纯代码实现前端页面压缩

2021-06-25
298次阅读
一条评论

前端代码压缩能有效缩小页面大小,减少传输时间,从而减少用户访问的等待时间。

使用下面的这个方法前提是,你的服务器性能要足够,因为代码生成是需要时间压缩页面再返回给前端的。我个人建议使用缓存插件搭配这个代码使用,这样能第一次压缩之后缓存在节点或者本地,从而下次用户访问直接调用对于的html文件,不需要程序再次压缩代码返回了。

wordpress纯代码实现前端页面压缩

用法:

将下面的代码放到 你当前主题的 functions.php 文件中,建议放在最底部,这样不容易出错。

代码:

// 压缩前端代码  https://www.linpx.com/p/pinghsu-subject-integration-code-compression.html
function mk_compress_html_main($html_source) {
    $chunks = preg_split('/(.*?|.*?</nocompress>|||)/msi', $html_source, -1, PREG_SPLIT_DELIM_CAPTURE); $compress = ''; foreach ($chunks as $c) { if (strtolower(substr($c, 0, 19)) == '') { $c = substr($c, 19, strlen($c) - 19 - 20); $compress .= $c; continue; } else if (strtolower(substr($c, 0, 12)) == '') { $c = substr($c, 12, strlen($c) - 12 - 13); $compress .= $c; continue; } else if (strtolower(substr($c, 0, 4)) == ' $char) {
                        if ($char == '"' && $chars[$key - 1] != '' && !$is_apos) {
                            $is_quot = !$is_quot;
                        } else if ($char == ''' && $chars[$key - 1] != '' && !$is_quot) {
                            $is_apos = !$is_apos;
                        } else if ($char == '/' && $chars[$key + 1] == '/' && !$is_quot && !$is_apos) {
                            $tmp = substr($tmp, 0, $key);
                            break;
                        }
                    }
                }
                $c .= $tmp;
            }
        }
        $c = preg_replace('/[nrt]+/', ' ', $c);
        $c = preg_replace('/s{2,}/', ' ', $c);
        $c = preg_replace('/>s <', $c);
        // 去除注释(可选)
        // $c = preg_replace('//*.*?*//i', '', $c);
        // $c = preg_replace('//', '', $c);
        $compress .= $c;
    }
    return $compress;
}
function mk_compress_html() {
    ob_start('mk_compress_html_main');
}
add_action('get_header', 'mk_compress_html');

正文结束
居烽
版权声明:本站原创文章,由 居烽 于2021-06-25发表,共计1255字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
评论(一条评论)
验证码
2021-12-07 07:07:02 回复

过来踩踩。。。

 Windows  Firefox  中国广东省深圳市电信