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

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

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

代码:

// 压缩前端代码  https://www.linpx.com/p/pinghsu-subject-integration-code-compression.html
function mk_compress_html_main($html_source) {
    $chunks = preg_split('/(.*?|.*?<\/nocompress>|<pre.*?\/pre>|<textarea.*?\/textarea>|<script.*?\/script>)/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)) == '<pre' || strtolower(substr($c, 0, 9)) == '<textarea') {
            $compress .= $c;
            continue;
        } else if (strtolower(substr($c, 0, 7)) == '<script' && strpos($c, '//') != false && (strpos($c, "\r") !== false || strpos($c, "\n") !== false)) { $tmps = preg_split('/(\r|\n)/ms', $c, -1, PREG_SPLIT_NO_EMPTY); $c = ''; foreach ($tmps as $tmp) { if (strpos($tmp, '//') !== false) { if (substr(trim($tmp), 0, 2) == '//') { continue; } $chars = preg_split('//', $tmp, -1, PREG_SPLIT_NO_EMPTY); $is_quot = $is_apos = false; foreach ($chars as $key => $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('/[\\n\\r\\t]+/', ' ', $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');
赞(0) 打赏
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《wordpress纯代码实现前端页面压缩》
文章链接:https://www.qqooo.cn/74.html
本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。
本站资源均来源于网络,若侵犯您的权益,请来信 xsds@vip.qq.com 删除!

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏