Mar*_*iry 9 php caching assets symfony twig
Symfony2是否可以通过文件使用assets_version?
我们使用assets_version和assets_version_format来管理文件版本并强制在CDN和浏览器缓存上进行缓存更新.
这就像魅力!,但是,我们发现assets_version所有静态资源只有一个参数.
这是一个问题,因为我们的webapp具有大量静态资源,而且我们每天都在对prod环境进行更改.这种情况会杀死缓存.:(
这是我们当前的配置:
config.yml
framework:
templating:
engines: ['twig']
assets_version: %assets_version%
assets_version_format: "stv%%2$s/%%1$s"
# Assetic Configuration
assetic:
debug: %kernel.debug%
use_controller: false
# java: /usr/bin/java
filters:
cssrewrite: ~
closure:
jar: %kernel.root_dir%/java/compiler.jar
yui_css:
jar: %kernel.root_dir%/java/yuicompressor-2.4.6.jar
Run Code Online (Sandbox Code Playgroud)
sometemplate.html.twig
{% stylesheets 'bundles/webapp/css/funCommon.css'
'bundles/webapp/css/funMobile.css'
filter='?yui_css'
%}
<link rel=stylesheet href='{{ asset_url }}'>
{% endstylesheets %}
{% javascripts 'bundles/webapp/js/app.js'
'bundles/webapp/js/utils.js'
filter='?closure' %}
<script src="{{ asset_url }}"></script>
{% endjavascripts %}
{% javascripts 'bundles/webapp/js/moduleX.js'
'bundles/webapp/js/utilsX.js'
filter='?closure' %}
<script src="{{ asset_url }}"></script>
{% endjavascripts %}
Run Code Online (Sandbox Code Playgroud)
当我更改任何 css文件或模块JS或任何其他文件时,所有路径都会更改.
我想通过javascript/stylesheet twig标签的参数来管理assets_version_format的version参数.
这就是我要找的东西:
{% javascripts 'bundles/webapp/js/app.js'
'bundles/webapp/js/utils.js'
filter='?closure' **version='XX'** %}
<script src="{{ asset_url }}"></script>
{% endjavascripts %}
Run Code Online (Sandbox Code Playgroud)
Mar*_*iry 17
经过多天搜索,我发现了包装选项AsseticBundle
http://symfony.com/doc/2.0/reference/configuration/framework.html#full-default-configuration
使用该配置选项,我可以这样做:
{% javascripts file package='packageName' %}
Run Code Online (Sandbox Code Playgroud)
要么
{{asset(file,packageName)}}
Run Code Online (Sandbox Code Playgroud)
config.yml
framework:
templating:
engines: ['twig']
assets_version: %assets_version%
assets_version_format: "stv%%2$s/%%1$s"
packages:
css:
version: 6.1
version_format: "stv%%2$s/%%1$s"
jsApp:
version: 4.2
version_format: "stv%%2$s/%%1$s"
Run Code Online (Sandbox Code Playgroud)
sometemplate.html.twig
<link rel=stylesheet href='{{ asset('bundles/webapp/css/funCommon.css','css') }}'>
{% javascripts 'bundles/webapp/js/app.js'
'bundles/webapp/js/utils.js'
filter='?closure'
package='jsApp'
%}
<script src="{{ asset_url }}"></script>
{% endjavascripts %}
Run Code Online (Sandbox Code Playgroud)
这个输出是:
<link rel=stylesheet href="http://static.domain.com/stv6.1/css/HASH.css">
<script src="http://static.domain.com/stv4.2/js/HASH.js"></script>
Run Code Online (Sandbox Code Playgroud)
对我来说,这是按文件管理资产的最简单方法.
| 归档时间: |
|
| 查看次数: |
9537 次 |
| 最近记录: |