Documentação do Symfony - versão 3.4
Renderizada do repositório symfony-docs-pt-BR no Github
O Symfony e todos seus pacotes são perfeitamente gerenciados pelo Composer. O Bower é uma ferramenta de gerenciamento de dependências front-end, como Bootstrap ou jQuery. Como o Symfony é puramente uma estrutura back-end, ele não pode ajudá-lo muito com o Bower. Felizmente, ele é muito fácil de usar!
O Bower é construído sobre o Node.js. Certifique-se de que você tenha ele instalado e em seguida, execute:
1 | $ npm install -g bower
|
Após esse comando terminar, execute bower
em seu terminal para saber se
ele está instalado corretamente.
Tip
Se você não quer instalar o NodeJS no seu computador, você também pode usar o
BowerPHP (uma adaptação não oficial PHP do Bower). Tenha em mente que ele ainda está em
estado alfa. Se você estiver usando o BowerPHP, use bowerphp
ao invés de
bower
nos exemplos.
Normalmente, o Bower transfere tudo para dentro de um diretório bower_components
. No
Symfony, apenas os arquivos no diretório web/
são publicamente acessíveis, então, você
precisa configurar o Bower para baixar as dependências front-end lá. Para fazer isso, basta
criar um arquivo .bowerrc
com um novo destino (como web/assets/vendor
):
1 2 3 | {
"directory": "web/assets/vendor/"
}
|
Acredite ou não, mas você está agora pronto para usar o Bower em sua aplicação Symfony. Como um exemplo, você vai instalar o Bootstrap em seu projeto e incluí-lo em seu layout.
Para criar um arquivo bower.json
, basta executar bower init
. Agora você está pronto para
começar a adicionar as dependências em seu projeto. Por exemplo, para adicionar o Bootstrap em seu
bower.json
e baixá-lo, basta executar:
1 | $ bower install --save bootstrap
|
Isso irá instalar o Bootstrap e suas dependências em web/assets/vendor/
(ou
qualquer diretório que você configurou no .bowerrc
).
See also
Para mais detalhes sobre como usar o Bower, verifique a documentação do Bower.
Agora que as dependências estão instaladas, você pode incluir o bootstrap em seu template normalmente como faria com qualquer arquivo CSS/JS:
1 2 3 4 5 6 7 8 9 10 11 12 | {# app/Resources/views/layout.html.twig #}
<!doctype html>
<html>
<head>
{# ... #}
<link rel="stylesheet"
href="{{ asset('assets/vendor/bootstrap/dist/css/bootstrap.min.css') }}">
</head>
{# ... #}
</html>
|
1 2 3 4 5 6 7 8 9 10 11 12 13 | <!-- app/Resources/views/layout.html.php -->
<!doctype html>
<html>
<head>
{# ... #}
<link rel="stylesheet" href="<?php echo $view['assets']->getUrl(
'assets/vendor/bootstrap/dist/css/bootstrap.min.css'
) ?>">
</head>
{# ... #}
</html>
|
Ótimo trabalho! Seu site está agora usando Bootstrap. E você pode atualizar facilmente o bootstrap para a última versão e gerenciar outras dependências front-end também.
Atualmente, você provavelmente faz o commit dos assets baixados pelo Bower ao invés
de adicionar o diretório (por exemplo, web/assets/vendor
) ao seu arquivo .gitignore
:
1 | $ git add web/assets/vendor
|
Por quê? Ao contrário do Composer, o Bower atualmente não tem um recurso de “lock”,
significando que não há garantia de que a execução do comando bower install
em um servidor diferente
irá lhe fornecer os assets exatos que você tem em outras máquinas.
Para mais detalhes, leia o artigo Checking in front-end dependencies.
Mas, é bem provável que o Bower irá adicionar um recurso de lock futuramente (por exemplo, bower/bower#1748).