您的位置 首页

如何使用magento的HTML输出缓存

文章原文是 magento wiki 里的一篇文章: http://www.magentocommerce.c…

文章原文是 magento wiki 里的一篇文章:

http://www.magentocommerce.com/wiki/5_-_modules_and_development/block_cache_and_html_ouput

我会在下一篇文章给出另外的使用例子。

在magento中, 某一块的html 会被存入magento 缓存中。

如果你是初始安装一个magento系统,此时除了前端和后台的 头部缓存在magento cache中,其它的几乎都没有被magento缓存。

举例1:

缓存管理必须写在Block的初始化函数中:

class {NS}_{Module}_Block_{View} extends Mage_Core_Block_Template {
 
    protected function _construct()
    {
        $this->addData(array(
            'cache_lifetime'    => 120,
            'cache_tags'        => array(Mage_Catalog_Model_Product::CACHE_TAG),
        ));
    }   
 
}

在这个例子中,我们设置了缓存时间为120 秒,输出代码会被缓存直到产品缓存被清除。(当然是在缓存时间没到的情况下)

结果:

1. 保存任何产品都会删除这个缓存。

2.当你这么做的时候你会发现所有的产品页都是一样的。

举例2:

考虑下面的例子:

class {NS}_{Module}_Block_{View} extends Mage_Core_Block_Template {
 
    protected function _construct()
    {
        $this->addData(array(
            'cache_lifetime'    => 120,
            'cache_tags'        => array(Mage_Catalog_Model_Product::CACHE_TAG),
            'cache_key'            => $this->getProduct()->getId(),
        ));
    }   
 
}

结果:

1.不同的产品id 页面不同

2.保存任何产品都会删除这个缓存

举例3:

class {NS}_{Module}_Block_{View} extends Mage_Core_Block_Template {
 
    protected function _construct()
    {
        $this->addData(array(
            'cache_lifetime'    => 120,
            'cache_tags'        => array(Mage_Catalog_Model_Product::CACHE_TAG . "_" . $this->getProduct()->getId()),
            'cache_key'            => $this->getProduct()->getId(),
        ));
    }
   
}

结果:

1.不同的产品id 页面不同

2.只有改变指定的产品才会删除这个缓存

以上例子只针对产品,如果你想对产品分类做同样的事情你必须重写上面的模型(例子),添加一下内容:

public function cleanCache()
    {
        Mage::app()->cleanCache('catalog_category_'.$this->getId());
    }   
   
    protected function _beforeSave() {
        $this->cleanCache();
        return parent::_beforeSave();
    }

提示:

如果cache_lifetime 设置成为false 意味着缓存将不会过期。

此文章通过 python 爬虫创建,原文是自己的csdn 地址: 如何使用magento的HTML输出缓存

本文来自网络,不代表找知博客立场,转载请注明出处:http://zhaozhiyong.cn/103.html

作者: 于老大

关注微博
返回顶部
//