bubnov / twig-declension-bundle
Symfony3 扩展包用于词形变化
3.0.7
2016-11-09 14:59 UTC
Requires
- cijic/phpmorphy: ~0.3
- friendsofsymfony/jsrouting-bundle: ~2.0
- knplabs/knp-paginator-bundle: 2.*
- sensio/framework-extra-bundle: ~2.8|~3.0
- symfony/symfony: ~2.8|~3.0
- twig/twig: ~1.10
README
twig 过滤器
- 允许管理可变词和复数形式列表
- 作为扩展连接到 twig 模板引擎
- 在模板中将字符串应用于过滤器
- 在预先填充的表中查找可变词,并返回所需形式
- 如果数据库中没有相应的记录或变位为空,则返回原始字符串或主格
- 使用独立的 phpMorphology (phpmorphy) 库 (http://phpmorphy.sourceforge.net/dokuwiki/)
- 安装
Выполнить:
```sh
composer require bubnov/twig-declension-bundle: ~3.0
```
Добавить бандл в конфигурацию AppKernel
```php
// app/AppKernel.php
public function registerBundles()
{
return array(
// ...
new Bubnov\TwigDeclensionBundle\BubnovTwigDeclensionBundle(),
// ...
);
}
```
Обновить базу данных
```sh
bin/console doctrine:schema:update
```
или
```sh
bin/console doctrine:migrations:diff
bin/console doctrine:migrations:migrate
```
Настроить routing.yml
```yml
# app/routing.yml
bubnov-twig-declension-bundle:
resource: "@BubnovTwigDeclensionBundle/Resources/config/routing/routing.yml"
```
Тонкая настройка
```yml
# app/config.yml
bubnov_twig_declension:
pre_cache: false #(true по умолчанию) - загрузка сразу всех слов в словаре одним запросом к БД при первом обращении
auto_create: false #(true по умолчанию) - автоматическое создание форм слов, запрашиваемых в twig
- 使用
Добавить ссылку в административной панели или меню
```twig
{# Ваш шаблон меню/панели #}
<a href="{{ path('admin_twig_declension') }}">Слонения</a>
```
** Внимание! В контроллере используется контроль доступа. Пользователь должен обладать ролью ROLE_ADMIN непосредственно, либо по иерархии ролей (см. security.role_hierarchy)
Создать необходимые записи в административном интерфейсе
В данном примере мы создали запись "яблоко" и заполнили все падежи и множественные формы
Склонение:
```twig
{# Ваш шаблон #}
Ньютон получил по голове {{ 'яблоко' | declension('abl') }}
{# Получится 'Ньютон получил по голове яблоком' #}
```
Множественное число:
```twig
{# Ваш шаблон #}
В ящике лежат {{ 'яблоко' | declension('inf_multi') }}
{# Получится 'В ящике лежат яблоки' #}
```
Множественные формы:
```twig
{# Ваш шаблон #}
У меня в кармане 12 {{ 'яблоко' | declension('plural', 12) }}
{# Получится 'У меня в кармане 12 яблок' #}
```
- 键和格列表
* inf - именительный падеж
* inf_multi - именительный падеж множественного числа
* gen - родительный падеж
* gen_multi - родительный падеж множественного числа
* dat - дательный падеж
* acc - винительный падеж
* abl - творительный падеж
* pre - предложный падеж
* plural - множественные формы
- 自动填充词的形式
На странице добавления/обновления записи можно настроить автоматическое заполнение форм слова.
Для генерации url к контроллеру используется FOS\JsRoutingBundle
Подключите его в app/AppKernel.php (скорее всего он там уже есть)
```php
// app/AppKernel.php
public function registerBundles()
{
return array(
// ...
new FOS\JsRoutingBundle\FOSJsRoutingBundle(),
// ...
);
}
```
Подключите в html js-ассет 'bundles/fosjsrouting/js/router.js' и 'bundles/bubnovtwigdeclension/js/auto-declension.js'
```html
<script type="text/javascript" src="{{ asset('bundles/fosjsrouting/js/router.js') }}></script>
<script type="text/javascript" src="{{ asset('bundles/bubnovtwigdeclension/js/auto-declension.js') }}></script>
```
или
```html
{% javascripts
...
'bundles/fosjsrouting/js/router.js'
'bundles/bubnovtwigdeclension/js/auto-declension.js'
...
output='compiled/compiled.js'
%}
<script type="text/javascript" src="{{ asset_url }}"></script>
{% endjavascripts %}
```
Установите ассеты из бандла
```sh
app/console assets:install
```