stephanecollot / datetimepicker-bundle
Symfony Bundle 用于 Bootstrap 日期时间选择器
1.0.1
2015-02-27 05:46 UTC
Requires
- php: >=5.3
- symfony/framework-bundle: 2.*
- symfony/symfony: 2.*
This package is not auto-updated.
Last update: 2024-09-23 14:54:48 UTC
README
#DatetimepickerBundle
此包实现了 Bootstrap DateTime Picker,并将其作为表单类型应用于 Symfony 2.*。包结构受 GenemuFormBundle 的启发。
演示: http://www.malot.fr/bootstrap-datetimepicker/demo.php
请随意贡献、分支、发送合并请求和创建工单。
##安装
步骤 1: 安装 DatetimepickerBundle
将以下依赖项添加到您的 composer.json 文件中
{ "require": { "stephanecollot/datetimepicker-bundle": "dev-master" } }
然后运行
php composer.phar update stephanecollot/datetimepicker-bundle
步骤 2: 启用包
<?php // app/AppKernel.php public function registerBundles() { $bundles = array( // ... new SC\DatetimepickerBundle\SCDatetimepickerBundle(), ); }
# 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 %}
文档
日期时间选择器的文档在此: http://www.malot.fr/bootstrap-datetimepicker/#options
注意
从 php 'pickerOptions' => array('format'=>'dd MM yyyy - HH:ii p')
中获取的日期格式用于自动设置 Symfony 的日期格式,以便使其与 JavaScript 输出兼容。但存在一些问题,例如, php MM
在 PHP intl 翻译中显示 "décembre",在 Bootstrap 翻译中显示 "Decembre"。这就是为什么我编辑了 js/locales/bootstrap-datetimepicker.fr.js 的原因。