gpt4 book ai didi

php - Symfony2 assets 按文件版本控制

转载 作者:可可西里 更新时间:2023-10-31 23:03:02 24 4
gpt4 key购买 nike

问题

是否可以在 Symfony2 上使用 assets_version by file

背景

我们正在使用 assets_version 和 assets_version_format管理文件版本并强制对 CDN 和浏览器缓存进行缓存更新。

这很有效!但是,我们发现所有使用的静态资源只有一个 assets_version 参数。

这是一个问题,因为我们的 web 应用程序有大量静态资源,而且我们每天都在将更改部署到生产环境。这种情况会杀死缓存。 :(

这是我们当前的配置:

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

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 %}

当我更改任何 css 文件或模块 JS 或任何其他文件时,所有路径都会更改

我想通过 javascript/stylesheet twig 标签的参数来管理 assets_version_format 的版本参数。

这就是我要找的:

{% javascripts 'bundles/webapp/js/app.js'
'bundles/webapp/js/utils.js'
filter='?closure' **version='XX'** %}
<script src="{{ asset_url }}"></script>
{% endjavascripts %}

最佳答案

经过多天的搜索,我在 AsseticBundle

上找到了 packages 选项

http://symfony.com/doc/2.0/reference/configuration/framework.html#full-default-configuration

使用该配置选项我可以做这样的事情:

{% javascripts file package='packageName' %}

{{asset(file,packageName)}}

示例:

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"

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 %}

这个的输出是:

<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>

对我来说,这是按文件管理 Assets 版本的最简单方法。

关于php - Symfony2 assets 按文件版本控制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17795200/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com