我不明白为什么缩小会降低速度

时间:2014-03-14 19:30:22

标签: php minify fat-free-framework

这可能是我的错误,但无论如何,我使用的是无脂肪框架,它具有内置功能,可以将多个css / js缩小为单个文件,我认为这对优化有好处,但它会变成相反的。如果我单独保存js文件(并且它们位于我的html的末尾),则添加的总大小大约为364kb,并且似乎在1.5秒内并行加载。但是,如果我尝试加载组合版本,则单个文件大小约为343kb,但需要大约10秒才能加载。

我的缩小逻辑虽然有点不同。首先在模板中我调用一个函数来加载文件:

<script type="text/javascript" src="{{ @BM->minify('js','js/',array(
                                    'vendor/jQui/jquery-ui-1.10.4.custom.min.js',
                                    'vendor/datatables/jquery.dataTables.min.js',
                                    'vendor/bootstrap.min.js',
                                    'vendor/smartmenus-0.9.5/jquery.smartmenus.min.js',
                                    'vendor/smartmenus-0.9.5/addons/bootstrap/jquery.smartmenus.bootstrap.min.js',
                                    'vendor/smartmenus-0.9.5/addons/keyboard/jquery.smartmenus.keyboard.min.js',
                                    'plugins.js',
                                    'main.js'
                                )) }}"></script>

该函数设置适当的会话变量并返回路径。

public function minify($type='',$folderpath='css/',$files=array()){
        $filepaths = implode(",",$files);
        $this->f3->set('SESSION.UI_'.$type,$this->themeRelFolder().'/'.$folderpath); 
        $this->f3->set('SESSION.ReplaceThemePath_'.$type,$this->themeRelFolder());
        $this->f3->set('SESSION.m_'.$type,$filepaths);
        return($this->f3->get('BASE').'/minify/'.$type);
    }

路径映射到控制器,该控制器调用minify方法并吐出实际的缩小内容。

public function index($f3, $params) {
        $f3->set('UI',$f3->get('SESSION.UI_'.$params['type'])); 
        if($params['type']=='css'){
            echo str_replace("<<themePath>>","../".$f3->get('SESSION.ReplaceThemePath_'.$params['type'])."/",\Web::instance()->minify($f3->get('SESSION.m_'.$params['type'])));
        }else
        {
            echo \Web::instance()->minify($f3->get('SESSION.m_'.$params['type']));
        }
    }

我是这样做的,这样我就可以缩小所需模板的文件数量,并且无论主题内的文件夹嵌套结构如何,都能够维护文件路径。

我做错了什么?

PS:我在我的本地wamp设置上测试它,而不是实际的服务器,因此加载时间明显不同于实际的Web服务器。

2 个答案:

答案 0 :(得分:2)

似乎引擎每次都在重新缩小。我敢打赌,你只需要设置缓存 - http://fatfreeframework.com/web#minify

  

要获得最佳性能,您可以启用F3系统缓存和   F3将使用它来保存/检索文件以缩小和保存   综合输出。您可以查看缓存引擎用户   指南了解更多详情。

http://fatfreeframework.com/quick-reference#cache

  

缓存后端。 F3可以处理Memcache模块,APC,WinCache,XCache   和基于文件系统的缓存。

     

例如:如果您想使用memcache模块,那么配置   字符串是必需的,例如$ f3-&gt; set('CACHE','memcache = localhost')(端口   默认为11211)或$ f3-&gt; set('CACHE','memcache = 192.168.72.72:11212')。

答案 1 :(得分:1)

每次加载页面时,您都会在运行时缩小这些文件。显然,这需要时间。

考虑缩小一次,然后只链接到那个文件。