serverti / scdatetimepicker-bundle
Symfony 为 Bootstrap DateTime picker 提供的扩展包
v2.0.1
2019-04-27 00:55 UTC
Requires
- symfony/framework-bundle: ~2.8 || ~3.0
This package is auto-updated.
Last update: 2024-09-14 10:56:41 UTC
README
#DatetimepickerBundle
本扩展包实现了 Bootstrap DateTime Picker,用于 Symfony 6 的表单类型。扩展包的结构灵感来源于 GenemuFormBundle。
请随时贡献、分支、发送合并请求和创建工单。
##安装
步骤 1:安装 DatetimepickerBundle
php composer.phar require serverti/scdatetimepicker-bundle
步骤 2:启用扩展包
# app/config/config.yml sc_datetimepicker: picker: ~
步骤 3:初始化资源
$ php app/console assets:install web/
用法
<?php // ... use SC\DatetimepickerBundle\Form\Type\DatetimeType; public function buildForm(FormBuilder $builder, array $options) { $builder // defaut options ->add('createdAt', DatetimeType::class) // full options ->add('updatedAt', DatetimeType::class, array( 'pickerOptions' => array('format' => 'mm/dd/yyyy', 'weekStart' => 0, 'startDate' => date('m/d/Y'), //example 'endDate' => '01/01/3000', //example 'daysOfWeekDisabled' => '0,6', //example 'autoclose' => false, 'startView' => 'month', 'minView' => 'hour', 'maxView' => 'decade', 'todayBtn' => false, 'todayHighlight' => false, 'keyboardNavigation' => true, 'language' => 'en', 'forceParse' => true, 'minuteStep' => 5, 'pickerReferer ' => 'default', //deprecated 'pickerPosition' => 'bottom-right', 'viewSelect' => 'hour', 'showMeridian' => false, 'initialDate' => date('m/d/Y', 1577836800), //example ))) ; }
添加 form_javascript 和 form_stylesheet
原则是将 JavaScript、样式表和 HTML 分开。这允许更好地整合网页。
示例
{% block stylesheets %} <link href="{{ asset('css/bootstrap.min.css') }}" rel="stylesheet" /> {{ form_stylesheet(form) }} {% endblock %} {% block javascripts %} <script src="{{ asset('js/jquery.min.js') }}"></script> <script src="{{ asset('js/bootstrap.min.js') }}"></script> {{ form_javascript(form) }} {% endblock %} {% block body %} <form action="{{ path('my_route_form') }}" type="post" {{ form_enctype(form) }}> {{ form_widget(form) }} <input type="submit" /> </form> {% endblock %}
注意事项
从 php 'pickerOptions' => array('format'=>'dd MM yyyy - HH:ii p')
中的日期格式用于自动设置 Symfony 的日期格式,以便使 Symfony 和 JavaScript 输出兼容。但是,存在一些问题,例如 php MM
在 PHP intl 翻译中显示为 "décembre",在 Bootstrap 翻译中显示为 "Decembre"。这就是为什么我编辑了 js/locales/bootstrap-datetimepicker.fr.js 的原因。