Symfony2和Twitter Bootstrap glyphicons

mag*_*_al 3 php symfony assetic twitter-bootstrap-3

我创建了一个Bundle,以便将Twitter Bootstap包含到我的项目中.我知道,那里有现有的套装,但我不想自己控制它.这意味着我不想安装Less编译器和类似的东西.

如果我将以下内容包含在我的模板中,则可以很好地应用.js和.css文件:

{% block javascripts %}
{% javascripts
'@MyAssetBundle/Resources/public/js/jquery.min.js'
'@MyAssetBundle/Resources/public/js/bootstrap.js' %}
<script type="text/javascript" src="{{ asset_url }}"></script>
{% endjavascripts %}
{% endblock %}

{% block stylesheets %}
{% stylesheets '@MyAssetBundle/Resources/public/css/*' filter='cssrewrite' %}
    <link rel="stylesheet" href="{{ asset_url }}" />
{% endstylesheets %}
{% endblock %}
Run Code Online (Sandbox Code Playgroud)

我只是努力包括适当的字体才能使用Bootstrap提供的glyphicons.

根据css定义,字体应该在相对于css文件的../fonts中可用.事实上我把它们放在那里.但Symfony2将这些相对网址解析为绝对路径,并没有为此找到路径.

我怎么解决这个问题?我真的觉得我没有在这里得到Symfony2概念的重要部分.

alb*_*igo 6

使用cssrewriteAssetic提供的过滤器来更正CSS文件中的路径.

{% stylesheets filter='cssrewrite'
    'bundles/myassetbundle/css/bootstrap.min.css' %}
    <link rel="stylesheet" href="{{ asset_url }}" />
{% endstylesheets %}
Run Code Online (Sandbox Code Playgroud)

确保使用的是bundles/myassetbundle/...符号而不是符号@MyAssetBundle.

阅读有关此事的Symfony文档.

  • 嗯,这种方式是正确的,请参阅文档.所以它应该工作.也许你没有正确地倾销你的资产.尝试`cache:clear`,然后`assets:install`然后`assetic:dump`.检查安装资产后,所有内容都在`web`目录下. (2认同)