codecamp
Fecshop 缓存

FecShop 缓存

fecshop 有整页缓存和局部缓存

整页缓存 - full page cache

实现原理为yii2的full page cache

配置:

@appfront/config/fecshop_local_services/Cache.php

具体如下:

return [
    'cache' => [
        /**
         * cache 总开关,设置false后,无论cacheConfig中的enable
         * 是否为true,都会全部关闭掉cache。
         */
        'enable'=> true,     
        /**
         * 各个页面cache的配置
         */
        'cacheConfig'   => [
            # 分类页面
            'category'  => [
                'enable'        => true,     # 是否开启分类页面的缓存
                'timeout'       => 3600,     # 则设置缓存的过期时间,这里设置为秒
                'disableUrlParam' => 'fecshop', # 如果开启缓存,在url加入什么参数后,系统不读取缓存,这个选项是为了方便在不刷新缓存的情况下,查看无缓存的页面是什么样子。
                # url出现的这些参数的值,将参与cache唯一key的生成。
                'cacheUrlParam' => [
                    # 分页,排序,等参数 
                    'p','dir','sort','numPerPage',
                    # 侧栏属性过滤等参数
                    'price','size','color',
                    'style','dresses-length','pattern-type',
                    'collar','xinghao','cpu'
                ],
            ],
            # 产品页面
            'product'  => [
                'enable'        => true,     # 是否开启产品页面的缓存
                'timeout'       => 3600,     #则设置缓存的过期时间,这里设置为秒
                'disableUrlParam' => 'fecshop', # 如果开启缓存,在url加入什么参数后,系统不读取缓存,这个选项是为了方便在不刷新缓存的情况下,查看无缓存的页面是什么样子。
            ],

            
            # 首页页面
            'home'  => [
                'enable'        => true,     # 是否开启首页页面的缓存
                'timeout'       => 3600,     # 则设置缓存的过期时间,这里设置为秒
                'disableUrlParam' => 'fecshop', # 如果开启缓存,在url加入什么参数后,系统不读取缓存,这个选项是为了方便在不刷新缓存的情况下,查看无缓存的页面是什么样子。
            ],

            
            # Article(page)页面
            'article'  => [
                'enable'        => true,     # 是否开启Article页面的缓存
                'timeout'       => 3600,     # 则设置缓存的过期时间,这里设置为秒
                'disableUrlParam' => 'fecshop',# 如果开启缓存,在url加入什么参数后,系统不读取缓存,这个选项是为了方便在不刷新缓存的情况下,查看无缓存的页面是什么样子。
            ],
        ],
    ],
];

详细看里面的注释代表的具体含义。

开启缓存后,页面的数据将从cache中读取,页面的动态数据部分,会 通过ajax的方式把页面的动态数据加载过来。 通过整页缓存,页面的加载就会非常的快。

局部缓存

局部缓存,相当于一个区块, 譬如fecshop pc端web的menu部分,头部header部分,尾部footer部分等,都可以 通过局部缓存的方式,将其缓存起来, 在购物车,下单,账户中心等内容全部是动态内容,不能做全页缓存的页面, 可以通过局部缓存的方式缓存某些非动态内容的区块, fecshop是通过 page - widget 服务实现的。

首先参看配置文件:

@appfront/config/fecshop_local_services/Page.php , 代码如下:

'widget' => [
    'widgetConfig' => [
        'head' => [
            # 动态数据提供部分
            'class' => 'fecshop\app\appfront\widgets\Head',
            # 根据多模板的优先级,依次去模板找查找该文件,直到找到这个文件。
            'view'  => 'widgets/head.php',
            # 缓存
            'cache' => [
                'enable'    => false, # 是否开启
                'timeout'   => 4500,  # 缓存过期时间
            ],
        ],
        'header' => [
            'class' => 'fecshop\app\appfront\widgets\Headers',
            # 根据多模板的优先级,依次去模板找查找该文件,直到找到这个文件。
            'view'  => 'widgets/header.php',
            'cache' => [
                'enable'    => false,
                'timeout'   => 4500,
            ],
        ],
        'topsearch' => [
            'view'  => 'widgets/topsearch.php',
        ],
        'menu' => [
            'class' => 'fecshop\app\appfront\widgets\Menu',
            # 根据多模板的优先级,依次去模板找查找该文件,直到找到这个文件。
            'view'  => 'widgets/menu.php',
            'cache' => [
                'enable'    => false,
                //'timeout'     => 4500,
            ],
        ],
        'footer' => [
            'class' => 'fecshop\app\appfront\widgets\Footer',
            # 根据多模板的优先级,依次去模板找查找该文件,直到找到这个文件。
            'view'  => 'widgets/footer.php',
            'cache' => [
                'enable'    => false,
                //'timeout'     => 4500,
            ],
        ],
        'scroll' => [
            #'class' => 'fecshop\app\appfront\modules\Cms\block\widgets\Scroll',
            # 根据多模板的优先级,依次去模板找查找该文件,直到找到这个文件。
            'view'  => 'widgets/scroll.php',
        ],
        'breadcrumbs' => [
            'view'  => 'widgets/breadcrumbs.php',
        ],
        'flashmessage' => [
            'view'  => 'widgets/flashmessage.php',
        ],
    ]
],

上面是各个区块的配置, 各个区块的调用方式为:

<?= Yii::$service->page->widget->render('menu',$this); ?>

如果上面的配置设置了cache 为开启,并且class对应的动态数据提供对象, 存在函数 getCacheKey ,则可以使用缓存

譬如:head的配置如下,下面定义了cache是否开启,如果设置为true,则 代表开启缓存, timeout代表缓存的过期时间。

'head' => [
            # 动态数据提供部分
            'class' => 'fecshop\app\appfront\widgets\Head',
            # 根据多模板的优先级,依次去模板找查找该文件,直到找到这个文件。
            'view'  => 'widgets/head.php',
            # 缓存
            'cache' => [
                'enable'    => false, # 是否开启
                'timeout'   => 4500,  # 缓存过期时间
            ],
        ],

上面配置中的class对应的Head.php文件内容为:

<?php
namespace fecshop\app\appfront\widgets;
use Yii;
use fecshop\interfaces\block\BlockCache;
class Head implements BlockCache
{
    public function getLastData()
    {
        return [

            
        ];
    }

    
    public function getCacheKey(){
        $store = Yii::$service->store->currentStore;
        $moduleId = Yii::$app->controller->module->id;
        $controllerId = Yii::$app->controller->id;
        $actionId = Yii::$app->controller->action->id;
        $urlPathKey = $moduleId.'_'.$controllerId.'_'.$actionId;
        return self::BLOCK_CACHE_PREFIX.'_'.$store.'_'.$urlPathKey;

    
    }
}

getCacheKey() 返回的是cache的唯一key。

通过上面的配置可以看出,headheaderfootermenu 都是可以设置局部缓存的。

Fecshop 验证码
Fecshop 搜索
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

Fecshop 简介

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }