首页 / 跨境电商轻量软件 / 实操指南:提升WooCommerce产品页加载速度的3个关键技术

实操指南:提升WooCommerce产品页加载速度的3个关键技术

实操指南:提升WooCommerce产品页加载速度的3个关键技术

引言:为什么WooCommerce产品页速度至关重要

在当今电子商务竞争激烈的环境中,网站加载速度直接影响着用户体验、转化率和搜索引擎排名。根据Google的研究,页面加载时间每增加1秒,移动端转化率就会下降20%。对于基于WordPress和WooCommerce搭建的在线商店而言,产品页通常是用户做出购买决策的关键页面,其性能优化尤为重要。

WooCommerce作为WordPress最流行的电子商务插件,虽然功能强大,但如果不进行适当优化,产品页很容易变得臃肿缓慢。本文将从代码开发角度,为行业新人和程序员提供三个关键技术,帮助您显著提升WooCommerce产品页的加载速度。

技术一:优化数据库查询与对象缓存

1.1 WooCommerce数据库查询分析

WooCommerce产品页通常涉及多个数据库查询,包括产品信息、变体数据、库存状态、评论、相关产品等。默认情况下,这些查询可能不是最优的。

常见性能瓶颈:

  • 重复查询相同数据
  • 未充分利用索引
  • N+1查询问题(获取产品列表后再逐个查询每个产品的详细信息)

1.2 实施数据库查询优化

示例代码:优化产品数据获取

/**
 * 优化获取产品数据的方法
 * 避免在循环中执行额外查询
 */
function optimized_get_product_data($product_id) {
    // 使用transient缓存产品数据
    $cache_key = 'product_data_' . $product_id;
    $product_data = get_transient($cache_key);
    
    if (false === $product_data) {
        global $wpdb;
        
        // 单次查询获取所有必要产品数据
        $product_data = $wpdb->get_row($wpdb->prepare("
            SELECT p.*, 
                   pm1.meta_value as _price,
                   pm2.meta_value as _regular_price,
                   pm3.meta_value as _sale_price,
                   pm4.meta_value as _stock_status
            FROM {$wpdb->posts} p
            LEFT JOIN {$wpdb->postmeta} pm1 ON (p.ID = pm1.post_id AND pm1.meta_key = '_price')
            LEFT JOIN {$wpdb->postmeta} pm2 ON (p.ID = pm2.post_id AND pm2.meta_key = '_regular_price')
            LEFT JOIN {$wpdb->postmeta} pm3 ON (p.ID = pm3.post_id AND pm3.meta_key = '_sale_price')
            LEFT JOIN {$wpdb->postmeta} pm4 ON (p.ID = pm4.post_id AND pm4.meta_key = '_stock_status')
            WHERE p.ID = %d
            AND p.post_type = 'product'
            AND p.post_status = 'publish'
            LIMIT 1
        ", $product_id));
        
        // 缓存12小时
        set_transient($cache_key, $product_data, 12 * HOUR_IN_SECONDS);
    }
    
    return $product_data;
}

// 清除产品数据缓存的钩子
add_action('save_post_product', 'clear_product_data_cache');
function clear_product_data_cache($post_id) {
    delete_transient('product_data_' . $post_id);
}

1.3 实现对象缓存策略

WordPress对象缓存(Object Caching)可以显著减少数据库查询次数。对于WooCommerce,我们可以缓存频繁访问的产品对象。

示例代码:增强WooCommerce对象缓存

/**
 * 扩展WooCommerce产品缓存
 */
class WooCommerce_Product_Cache_Enhancer {
    
    private static $instance = null;
    private $cache_group = 'woocommerce_products';
    
    public static function get_instance() {
        if (null === self::$instance) {
            self::$instance = new self();
        }
        return self::$instance;
    }
    
    /**
     * 获取带缓存的产品对象
     */
    public function get_product($product_id) {
        $cache_key = 'product_object_' . $product_id;
        $product = wp_cache_get($cache_key, $this->cache_group);
        
        if (false === $product) {
            $product = wc_get_product($product_id);
            
            if ($product) {
                // 缓存产品对象,设置1小时过期
                wp_cache_set($cache_key, $product, $this->cache_group, 3600);
                
                // 同时缓存价格信息等常用数据
                $this->cache_product_meta($product_id, $product);
            }
        }
        
        return $product;
    }
    
    /**
     * 缓存产品元数据
     */
    private function cache_product_meta($product_id, $product) {
        $meta_cache_key = 'product_meta_' . $product_id;
        $meta_data = array(
            'price' => $product->get_price(),
            'regular_price' => $product->get_regular_price(),
            'sale_price' => $product->get_sale_price(),
            'stock_status' => $product->get_stock_status(),
            'average_rating' => $product->get_average_rating(),
        );
        
        wp_cache_set($meta_cache_key, $meta_data, $this->cache_group, 1800);
    }
    
    /**
     * 清除产品缓存
     */
    public function clear_product_cache($product_id) {
        wp_cache_delete('product_object_' . $product_id, $this->cache_group);
        wp_cache_delete('product_meta_' . $product_id, $this->cache_group);
    }
}

// 初始化缓存增强器
add_action('init', function() {
    WooCommerce_Product_Cache_Enhancer::get_instance();
});

// 产品更新时清除缓存
add_action('woocommerce_update_product', function($product_id) {
    $cache_enhancer = WooCommerce_Product_Cache_Enhancer::get_instance();
    $cache_enhancer->clear_product_cache($product_id);
});

1.4 数据库索引优化建议

为WooCommerce相关表添加适当索引可以大幅提升查询性能:

-- 为常用查询字段添加索引
CREATE INDEX idx_product_meta_post_id ON wp_postmeta(post_id);
CREATE INDEX idx_product_meta_key ON wp_postmeta(meta_key(50));
CREATE INDEX idx_product_price ON wp_postmeta(meta_key(50), meta_value) WHERE meta_key = '_price';

-- 优化订单查询(如果产品页显示购买记录)
CREATE INDEX idx_order_items_product_id ON wp_woocommerce_order_items(order_item_type, order_id);

技术二:前端资源优化与延迟加载

2.1 分析WooCommerce产品页资源加载

典型WooCommerce产品页可能加载的资源包括:

  • WooCommerce主CSS和JS文件
  • 主题样式和脚本
  • 产品图库脚本(FlexSlider、Zoom等)
  • 评论和评分相关资源
  • 社交媒体分享脚本
  • 第三方分析跟踪代码

2.2 实施CSS和JavaScript优化

示例代码:优化资源加载策略

/**
 * 优化WooCommerce前端资源加载
 */
function optimize_woocommerce_assets() {
    // 如果不是产品页,移除不必要的WooCommerce资源
    if (!is_product()) {
        wp_dequeue_style('woocommerce-general');
        wp_dequeue_style('woocommerce-layout');
        wp_dequeue_style('woocommerce-smallscreen');
        wp_dequeue_script('wc-add-to-cart');
        wp_dequeue_script('wc-cart-fragments');
    }
    
    // 在产品页优化资源加载
    if (is_product()) {
        // 延迟加载非关键CSS
        add_filter('style_loader_tag', 'defer_non_critical_css', 10, 2);
        
        // 异步加载非关键JS
        add_filter('script_loader_tag', 'async_defer_scripts', 10, 2);
        
        // 移除不必要的脚本
        wp_deregister_script('jquery-blockui');
        wp_deregister_script('jquery-placeholder');
    }
}

add_action('wp_enqueue_scripts', 'optimize_woocommerce_assets', 99);

/**
 * 延迟加载非关键CSS
 */
function defer_non_critical_css($html, $handle) {
    // 定义关键CSS(立即加载)
    $critical_styles = array(
        'woocommerce-general',
        'theme-main-style',
        'product-page-critical'
    );
    
    // 定义可以延迟加载的CSS
    $deferrable_styles = array(
        'woocommerce-smallscreen',
        'font-awesome',
        'magnific-popup'
    );
    
    if (in_array($handle, $deferrable_styles)) {
        return str_replace("rel='stylesheet'", "rel='preload' as='style' onload="this.onload=null;this.rel='stylesheet'"", $html);
    }
    
    return $html;
}

/**
 * 异步或延迟加载JavaScript
 */
function async_defer_scripts($tag, $handle) {
    // 异步加载的脚本(不影响页面渲染)
    $async_scripts = array(
        'woocommerce',
        'wc-add-to-cart-variation',
        'zoom'
    );
    
    // 延迟加载的脚本(在页面加载完成后执行)
    $defer_scripts = array(
        'jquery',
        'wc-single-product',
        'social-share-buttons'
    );
    
    if (in_array($handle, $async_scripts)) {
        return str_replace(' src', ' async src', $tag);
    }
    
    if (in_array($handle, $defer_scripts)) {
        return str_replace(' src', ' defer src', $tag);
    }
    
    return $tag;
}

2.3 实现图片优化与延迟加载

示例代码:优化产品图片加载

/**
 * 优化WooCommerce产品图片
 */
class WooCommerce_Image_Optimizer {
    
    /**
     * 生成响应式图片标记
     */
    public static function get_responsive_product_image($product_id, $size = 'woocommerce_single', $attr = array()) {
        $product = wc_get_product($product_id);
        
        if (!$product) {
            return '';
        }
        
        $image_id = $product->get_image_id();
        $full_src = wp_get_attachment_image_src($image_id, 'full');
        $main_src = wp_get_attachment_image_src($image_id, $size);
        
        if (!$main_src) {
            return wc_placeholder_img($size);
        }
        
        // 生成srcset和sizes属性
        $srcset = wp_get_attachment_image_srcset($image_id, $size);
        $sizes = wp_get_attachment_image_sizes($image_id, $size);
        
        $default_attr = array(
            'src' => $main_src[0],
            'alt' => get_post_meta($image_id, '_wp_attachment_image_alt', true) ?: $product->get_name(),
            'class' => 'woocommerce-product-image lazy-load',
            'data-src' => $main_src[0],
            'data-srcset' => $srcset,
            'data-sizes' => $sizes,
            'loading' => 'lazy', // 原生懒加载
        );
        
        $attr = wp_parse_args($attr, $default_attr);
        
        // 使用低质量占位图(LQIP)技术
        $placeholder = self::generate_placeholder($main_src[0]);
        $attr['src'] = $placeholder;
        
        $html = '<img';
        
        foreach ($attr as $name => $value) {
            $html .= ' ' . $name . '="' . esc_attr($value) . '"';
        }
        
        $html .= '>';
        
        // 添加加载后替换真实图片的JavaScript
        $html .= self::get_lazy_load_script();
        
        return $html;
    }
    
    /**
     * 生成低质量占位图
     */
    private static function generate_placeholder($image_url) {
        // 简单实现:使用极低质量版本或纯色占位
        // 实际项目中可以使用第三方服务或GD库生成
        
        // 这里返回一个1x1的透明GIF作为占位符
        return '';
    }
    
    /**
     * 懒加载脚本
     */
    private static function get_lazy_load_script() {
        ob_start();
        ?>
        <script>
        document.addEventListener('DOMContentLoaded', function() {
            // 使用Intersection Observer API实现懒加载
            if ('IntersectionObserver' in window) {
                const lazyImages = document.querySelectorAll('img.lazy-load');
                
                const imageObserver = new IntersectionObserver(function(entries, observer) {
                    entries.forEach(function(entry) {
                        if (entry.isIntersecting) {
                            const img = entry.target;
                            
                            // 加载真实图片
                            if (img.dataset.src) {
                                img.src = img.dataset.src;
                            }
                            
                            if (img.dataset.srcset) {
                                img.srcset = img.dataset.srcset;
                            }
                            
                            img.classList.remove('lazy-load');
                            imageObserver.unobserve(img);
                        }
                    });
                });
                
                lazyImages.forEach(function(img) {
                    imageObserver.observe(img);
                });
            } else {
                // 回退方案:加载所有图片
                document.querySelectorAll('img.lazy-load').forEach(function(img) {
                    if (img.dataset.src) {
                        img.src = img.dataset.src;
                    }
                    if (img.dataset.srcset) {
                        img.srcset = img.dataset.srcset;
                    }
                });
            }
        });
        </script>
        <?php
        return ob_get_clean();
    }
}

// 替换默认的WooCommerce产品图片输出
add_filter('woocommerce_product_get_image', 'custom_woocommerce_product_image', 10, 2);
function custom_woocommerce_product_image($image, $product) {
    if (is_product()) {
        return WooCommerce_Image_Optimizer::get_responsive_product_image($product->get_id());
    }
    return $image;
}

2.4 实施关键CSS内联和WebP支持

示例代码:内联关键CSS并支持现代图片格式

/**
 * 提取并内联关键CSS
 */
function inline_critical_css() {
    if (!is_product()) {
        return;
    }
    
    // 关键CSS文件路径
    $critical_css_path = get_stylesheet_directory() . '/css/critical-product.css';
    
    if (file_exists($critical_css_path)) {
        $critical_css = file_get_contents($critical_css_path);
        echo '<style>' . $critical_css . '</style>';
    } else {
        // 动态生成关键CSS
        $dynamic_critical_css = generate_dynamic_critical_css();
        echo '<style>' . $dynamic_critical_css . '</style>';
    }
}
add_action('wp_head', 'inline_critical_css', 1);

/**
 * 添加WebP图片支持
 */
function add_webp_support($html, $attachment_id) {
    if (is_product()) {
        $webp_url = wp_get_attachment_image_url($attachment_id, 'full', false);
        $webp_url = preg_replace('/.(jpg|jpeg|png)$/i', '.webp', $webp_url);
        
        // 检查WebP版本是否存在
        if (file_exists(str_replace(WP_CONTENT_URL, WP_CONTENT_DIR, $webp_url))) {
            $html = preg_replace('/<img/', '<picture><source srcset="' . esc_url($webp_url) . '" type="image/webp">' . $html . '</picture>', $html);
        }
    }
    
    return $html;
}
add_filter('wp_get_attachment_image', 'add_webp_support', 10, 2);

技术三:服务器端优化与缓存策略

3.1 实施页面级缓存

示例代码:实现WooCommerce产品页静态缓存

/**
 * WooCommerce产品页静态缓存
 */
class WooCommerce_Static_Cache {
    
    private $cache_dir;
    private $cache_time = 3600; // 1小时缓存
    
    public function __construct() {
        $this->cache_dir = WP_CONTENT_DIR . '/cache/woocommerce_pages/';
        
        if (!file_exists($this->cache_dir)) {
            wp_mkdir_p($this->cache_dir);
        }
        
        $this->init_hooks();
    }
    
    private function init_hooks() {
        // 在模板加载前检查缓存
        add_action('template_redirect', array($this, 'maybe_serve_cached_page'), 1);
        
        // 清除相关缓存
        add_action('save_post_product', array($this, 'clear_product_cache'));
        add_action('woocommerce_update_product', array($this, 'clear_product_cache'));
        add_action('woocommerce_update_product_variation', array($this, 'clear_product_cache'));
    }
    
    /**
     * 检查并返回缓存页面
     */
    public function maybe_serve_cached_page() {
        if (!is_product() || is_user_logged_in() || is_admin()) {
            return;
        }
        
        $product_id = get_queried_object_id();
        $cache_file = $this->cache_dir . 'product_' . $product_id . '.html';
        
        // 检查缓存是否存在且未过期
        if (file_exists($cache_file) && (time() - filemtime($cache_file)) < $this->cache_time) {
            // 读取并输出缓存
            readfile($cache_file);
            exit;
        }
        
        // 开始输出缓冲以捕获页面内容
        ob_start(array($this, 'cache_page_output'));
    }
    
    /**
     * 缓存页面输出
     */
    public function cache_page_output($buffer) {
        if (is_product() && !is_user_logged_in()) {
            $product_id = get_queried_object_id();
            $cache_file = $this->cache_dir . 'product_' . $product_id . '.html';
            
            // 保存到缓存文件
        // 添加缓存标记和过期时间
        $buffer .= "n<!-- Cached by WooCommerce_Static_Cache on " . date('Y-m-d H:i:s') . " -->";
        
        // 保存缓存文件
        file_put_contents($cache_file, $buffer);
    }
    
    return $buffer;
}

/**
 * 清除产品缓存
 */
public function clear_product_cache($product_id) {
    $cache_file = $this->cache_dir . 'product_' . $product_id . '.html';
    
    if (file_exists($cache_file)) {
        unlink($cache_file);
    }
    
    // 同时清除相关缓存(如分类页面)
    $this->clear_related_caches($product_id);
}

/**
 * 清除相关缓存
 */
private function clear_related_caches($product_id) {
    $product = wc_get_product($product_id);
    
    if (!$product) {
        return;
    }
    
    // 清除产品分类页面缓存
    $categories = $product->get_category_ids();
    foreach ($categories as $category_id) {
        $category_cache = $this->cache_dir . 'category_' . $category_id . '.html';
        if (file_exists($category_cache)) {
            unlink($category_cache);
        }
    }
}

}

// 初始化静态缓存
add_action('init', function() {

if (!is_admin() && !is_user_logged_in()) {
    new WooCommerce_Static_Cache();
}

});


### 3.2 实施OPCache和对象缓存优化

**示例代码:配置和监控OPCache**

/**

  • OPCache优化和监控
    */

class WooCommerce_OPCache_Manager {


/**
 * 检查并优化OPCache配置
 */
public static function optimize_opcache() {
    if (!function_exists('opcache_get_status')) {
        return false;
    }
    
    $status = opcache_get_status();
    $config = opcache_get_configuration();
    
    // 检查OPCache状态
    if ($status['opcache_enabled']) {
        // 监控内存使用
        $memory_usage = $status['memory_usage'];
        $used_memory = $memory_usage['used_memory'];
        $free_memory = $memory_usage['free_memory'];
        $total_memory = $used_memory + $free_memory;
        
        $memory_percentage = ($used_memory / $total_memory) * 100;
        
        // 如果内存使用超过90%,尝试清理
        if ($memory_percentage > 90) {
            self::clear_stale_cache();
        }
        
        // 优化WooCommerce相关文件的缓存
        self::preload_woocommerce_files();
    }
    
    return true;
}

/**
 * 预加载WooCommerce核心文件
 */
private static function preload_woocommerce_files() {
    $woocommerce_path = WP_PLUGIN_DIR . '/woocommerce/';
    
    $core_files = array(
        $woocommerce_path . 'woocommerce.php',
        $woocommerce_path . 'includes/class-woocommerce.php',
        $woocommerce_path . 'includes/wc-core-functions.php',
        $woocommerce_path . 'includes/class-wc-product.php',
        $woocommerce_path . 'includes/class-wc-product-simple.php',
        $woocommerce_path . 'includes/class-wc-product-variable.php',
    );
    
    foreach ($core_files as $file) {
        if (file_exists($file)) {
            opcache_compile_file($file);
        }
    }
}

/**
 * 清理过期的缓存
 */
private static function clear_stale_cache() {
    // 获取所有缓存文件
    $status = opcache_get_status();
    
    if (isset($status['scripts'])) {
        $scripts = $status['scripts'];
        $now = time();
        
        foreach ($scripts as $script) {
            // 如果文件超过1天未被访问,考虑清理
            if (($now - $script['last_used_timestamp']) > 86400) {
                opcache_invalidate($script['full_path'], true);
            }
        }
    }
}

/**
 * 获取OPCache统计信息
 */
public static function get_stats() {
    if (!function_exists('opcache_get_status')) {
        return array('enabled' => false);
    }
    
    $status = opcache_get_status();
    $config = opcache_get_configuration();
    
    return array(
        'enabled' => $status['opcache_enabled'],
        'memory_usage' => $status['memory_usage'],
        'statistics' => $status['opcache_statistics'],
        'config' => $config['directives'],
    );
}

}

// 定期优化OPCache
add_action('wp_loaded', 'WooCommerce_OPCache_Manager::optimize_opcache');

// 在管理后台显示OPCache状态
add_action('admin_bar_menu', function($wp_admin_bar) {

if (current_user_can('manage_options')) {
    $stats = WooCommerce_OPCache_Manager::get_stats();
    
    if ($stats['enabled']) {
        $hit_rate = $stats['statistics']['opcache_hit_rate'];
        $memory_used = round($stats['memory_usage']['used_memory'] / 1024 / 1024, 2);
        $memory_total = round(($stats['memory_usage']['used_memory'] + $stats['memory_usage']['free_memory']) / 1024 / 1024, 2);
        
        $title = sprintf('OPCache: %.1f%% Hit | %sMB/%sMB', 
            $hit_rate, $memory_used, $memory_total);
        
        $wp_admin_bar->add_node(array(
            'id' => 'opcache_status',
            'title' => $title,
            'href' => admin_url('admin.php?page=wc-status&tab=opcache'),
            'meta' => array('class' => 'opcache-status')
        ));
    }
}

}, 100);


### 3.3 实施CDN集成和边缘缓存

**示例代码:集成CDN并优化资源分发**

/**

  • CDN集成和优化
    */

class WooCommerce_CDN_Integration {


private $cdn_domain = 'cdn.yourdomain.com';
private $excluded_files = array('.php', '.xml', '.json');

public function __construct() {
    $this->init_hooks();
}

private function init_hooks() {
    // 重写静态资源URL
    add_filter('wp_get_attachment_url', array($this, 'rewrite_attachment_url'), 10, 2);
    add_filter('stylesheet_uri', array($this, 'rewrite_theme_assets'));
    add_filter('script_loader_src', array($this, 'rewrite_script_src'));
    add_filter('style_loader_src', array($this, 'rewrite_style_src'));
    
    // 添加资源提示
    add_action('wp_head', array($this, 'add_resource_hints'), 2);
    
    // 生成CDN友好的版本号
    add_filter('style_loader_src', array($this, 'add_version_query'));
    add_filter('script_loader_src', array($this, 'add_version_query'));
}

/**
 * 重写附件URL到CDN
 */
public function rewrite_attachment_url($url, $post_id) {
    if (wp_attachment_is_image($post_id)) {
        $parsed_url = parse_url($url);
        $cdn_url = 'https://' . $this->cdn_domain . $parsed_url['path'];
        
        // 添加WebP支持
        if (strpos($url, '.jpg') !== false || strpos($url, '.png') !== false) {
            $cdn_url = $this->maybe_add_webp($cdn_url);
        }
        
        return $cdn_url;
    }
    
    return $url;
}

/**
 * 重写主题资源URL
 */
public function rewrite_theme_assets($url) {
    $parsed_url = parse_url($url);
    
    // 只处理CSS和JS文件
    if (preg_match('/.(css|js)$/i', $parsed_url['path'])) {
        return 'https://' . $this->cdn_domain . $parsed_url['path'];
    }
    
    return $url;
}

/**
 * 重写脚本URL
 */
public function rewrite_script_src($src) {
    return $this->rewrite_to_cdn($src);
}

/**
 * 重写样式URL
 */
public function rewrite_style_src($src) {
    return $this->rewrite_to_cdn($src);
}

/**
 * 通用CDN重写逻辑
 */
private function rewrite_to_cdn($src) {
    if (empty($src)) {
        return $src;
    }
    
    $parsed_src = parse_url($src);
    
    // 排除特定文件
    foreach ($this->excluded_files as $excluded) {
        if (strpos($parsed_src['path'], $excluded) !== false) {
            return $src;
        }
    }
    
    // 检查是否是本地文件
    $site_url = parse_url(site_url());
    
    if (isset($parsed_src['host']) && $parsed_src['host'] === $site_url['host']) {
        return 'https://' . $this->cdn_domain . $parsed_src['path'];
    }
    
    return $src;
}

/**
 * 添加资源提示
 */
public function add_resource_hints() {
    if (!is_product()) {
        return;
    }
    
    echo '<link rel="dns-prefetch" href="//' . $this->cdn_domain . '">' . "n";
    echo '<link rel="preconnect" href="https://' . $this->cdn_domain . '" crossorigin>' . "n";
    
    // 预加载关键资源
    $product = wc_get_product(get_queried_object_id());
    if ($product) {
        $image_id = $product->get_image_id();
        $image_url = wp_get_attachment_image_url($image_id, 'woocommerce_single');
        
        if ($image_url) {
            $cdn_image_url = $this->rewrite_to_cdn($image_url);
            echo '<link rel="preload" as="image" href="' . esc_url($cdn_image_url) . '">' . "n";
        }
    }
}

/**
 * 添加版本查询参数
 */
public function add_version_query($src) {
    if (strpos($src, $this->cdn_domain) !== false) {
        $version = $this->get_file_version($src);
        return add_query_arg('ver', $version, $src);
    }
    
    return $src;
}

/**
 * 获取文件版本(基于修改时间)
 */
private function get_file_version($src) {
    $parsed_url = parse_url($src);
    $file_path = ABSPATH . str_replace(site_url('/'), '', $src);
    
    if (file_exists($file_path)) {
        return filemtime($file_path);
    }
    
    return get_bloginfo('version');
}

/**
 * 添加WebP支持
 */
private function maybe_add_webp($url) {
    // 检查浏览器是否支持WebP
    if (isset($_SERVER['HTTP_ACCEPT']) && strpos($_SERVER['HTTP_ACCEPT'], 'image/webp') !== false) {
        // 这里可以添加逻辑来检查WebP版本是否存在
        // 如果存在,返回WebP版本的URL
    }
    
    return $url;
}

}

// 初始化CDN集成
add_action('init', function() {

new WooCommerce_CDN_Integration();

});


### 3.4 实施HTTP/2服务器推送

**示例代码:配置HTTP/2服务器推送**

/**

  • HTTP/2服务器推送优化
    */

class WooCommerce_HTTP2_Push {


private $resources_to_push = array();

public function __construct() {
    $this->init_hooks();
}

private function init_hooks() {
    // 收集需要推送的资源
    add_action('wp_enqueue_scripts', array($this, 'collect_push_resources'), 999);
    
    // 发送HTTP/2推送头
    add_action('send_headers', array($this, 'send_http2_push_headers'));
}

/**
 * 收集需要推送的资源
 */
public function collect_push_resources() {
    if (!is_product()) {
        return;
    }
    
    global $wp_styles, $wp_scripts;
    
    // 收集关键CSS
    $this->add_style_to_push('woocommerce-general');
    $this->add_style_to_push('theme-main-style');
    
    // 收集关键JS
    $this->add_script_to_push('jquery');
    $this->add_script_to_push('wc-single-product');
    
    // 收集关键图片
    $product_id = get_queried_object_id();
    $product = wc_get_product($product_id);
    
    if ($product) {
        $image_id = $product->get_image_id();
        $image_url = wp_get_attachment_image_url($image_id, 'woocommerce_single');
        
        if ($image_url) {
            $this->resources_to_push[] = array(
                'path' => $this->get_relative_path($image_url),
                'type' => 'image'
            );
        }
    }
}

/**
 * 添加样式到推送列表
 */
private function add_style_to_push($handle) {
    global $wp_styles;
    
    if (isset($wp_styles->registered[$handle])) {
        $style = $wp_styles->registered[$handle];
        $this->resources_to_push[] = array(
            'path' => $this->get_relative_path($style->src),
            'type' => 'style'
        );
    }
}

/**
 * 添加脚本到推送列表
 */
private function add_script_to_push($handle) {
    global $wp_scripts;
    
    if (isset($wp_scripts->registered[$handle])) {
        $script = $wp_scripts->registered[$handle];
        $this->resources_to_push[] = array(
            'path' => $this->get_relative_path($script->src),
            'type' => 'script'
        );
    }
}

/**
 * 获取相对路径
 */
private function get_relative_path($url) {
    $site_url = site_url();
    return str_replace($site_url, '', $url);
}

/**
 * 发送HTTP/2推送头
 */
public function send_http2_push_headers() {
    if (empty($this->resources_to_push) || !is_product()) {
        return;
    }
    
    $link_header_values = array();
    
    foreach ($this->resources_to_push as $resource) {
        $as_type = $resource['type'] === 'image' ? 'image' : $resource['type'];
        $link_header_values[] = sprintf(
            '<%s>; rel=preload; as=%s',
            $resource['path'],
            $as_type
        );
    }
    
    if (!empty($link_header_values)) {
        header('Link: ' . implode(', ', $link_header_values), false);
    }
}

}

// 初始化HTTP/2推送
add_action('init', function() {

if (!is_admin()) {
    new WooCommerce_HTTP2_Push();
}

});


## 性能监控与持续优化

### 4.1 实施性能监控系统

**示例代码:创建性能监控仪表板**

/**

  • WooCommerce性能监控
    */

class WooCommerce_Performance_Monitor {


private $start_time;
private $queries_start;

public function __construct() {
    $this->init_hooks();
}

private function init_hooks() {
    // 开始计时
    add_action('wp', array($this, 'start_timing'));
    
    // 记录数据库查询
    add_filter('query', array($this, 'log_query'));
    
    // 在页脚显示性能数据
    add_action('wp_footer', array($this, 'display_performance_data'), 999);
    
    // 记录性能数据到日志
    add_action('shutdown', array($this, 'log_performance_data'));
}

/**
 * 开始计时
 */
public function start_timing() {
    $this->start_time = microtime(true);
    
    global $wpdb;
    $this->queries_start = $wpdb->num_queries;
}

/**
 * 记录查询
 */
public function log_query($query) {
    if (defined('SAVEQUERIES') && SAVEQUERIES) {
        // 查询已由WordPress记录
        return $query;
    }
    
    // 简单记录慢查询
    $start = microtime(true);
    
    // 执行查询后记录时间
    add_filter('query_result', function($result) use ($start, $query) {
        $time = microtime(true) - $start;
        
        if ($time > 0.1) { // 记录超过100ms的查询
            error_log(sprintf(
                'Slow Query (%.3fs): %s',
                $time,
                substr($query, 0, 200)
            ));
        }
        
        return $result;
    });
    
    return $query;
}

/**
 * 显示性能数据
 */
public function display_performance_data() {
    if (!current_user_can('manage_options')) {
        return;
    }
    
    $load_time = microtime(true) - $this->start_time;
    
    global $wpdb;
    $queries = $wpdb->num_queries - $this->queries_start;
    
    $memory = memory_get_peak_usage(true) / 1024 / 1024;
    
    echo '<div class="performance-monitor" style
本文来自网络,不代表柔性供应链服务中心立场,转载请注明出处:https://mall.org.cn/192.html

EXCHANGES®作者

上一篇
下一篇

为您推荐

联系我们

联系我们

18559313275

在线咨询: QQ交谈

邮箱: vip@exchanges.center

工作时间:周一至周五,9:00-17:30,节假日休息
返回顶部