第3.1.3章 WEB系统最佳实践 js控件之bootstrap-datepicker的使用

本文介绍如何使用RequireJS加载Bootstrap Datepicker插件,并详细解释了如何进行基本配置及自定义日期范围选择器,包括JavaScript配置选项和HTML结构。

bootstrap-datepicker沙箱环境
1 requirejs配置

requirejs.config({
    baseUrl: '../pages/modules',
//    urlArgs: "v=" + (new Date()).getTime(),//禁止缓存,生产环境去除
	urlArgs:'v=2016110701',
    paths: {
        jquery: ["../../plugins/jquery/jquery"],
        bootstrap: ["../../plugins/bootstrap/dist/js/bootstrap.min"],
        datepicker:["../../plugins/bootstrap-datepicker/dist/js/bootstrap-datepicker.min"],
        datepicker_zh:["../../plugins/bootstrap-datepicker/dist/locales/bootstrap-datepicker.zh-CN.min"]
    },
    shim: {
        bootstrap: {deps: ["jquery"],exports: 'bootstrap'},
        datepicker:{deps:["jquery"],exports:"datepicker"},
        datepicker_zh:{deps:["jquery","datepicker"],exports:"datepicker_zh"}
    }
});
require(['jquery', 'bootstrap']);

2 html

<div class="form-group col col-sm-3 padding no-margin-bottom" id="birthdayGroup">
                <label class="col col-sm-4 text-right form-label no-padding-left">出生日期:</label>
                <div class="col col-sm-8 no-padding-left no-padding-left input-group date">
                    <span class="input-group-addon">
                        <i class="fa fa-calendar"></i>
                    </span>
                    <input id="birthday" type="text" class="form-control" placeholder="出生日期"/>
                </div>
            </div>

3 js

var $ = require('jquery');
require('datepicker_zh');
$("#birthdayGroup .input-group.date").datepicker({todayHighlight:true,todayBtn: 'linked'
            ,keyboardNavigation:true,autoclose:true,language:'zh-CN',format:'yyyy-mm-dd'
            ,daysOfWeekHighlighted:'0,6'});

4 效果
日期
5 更改默认配置
如果每个控件都按照上述js的写法,是不是很痛苦。所以可以将您认为常用的配置设置到
默认配置
设置完毕后,要做的是日期的格式,因为bootstrap-datepicker.zh-CN.min.js将格式设置为了yyyy年mm月dd日,所以如果您想默认格式为’yyyy-mm-dd’,还得改bootstrap-datepicker.zh-CN.min.js这个地方.
中文日期
现在您只需要即可实现效果。
$("#birthdayGroup .input-group.date").datepicker();
6 时间段的日期
jsp页面重点是input-daterange input-group的样式

<div class="form-group col col-sm-4 padding no-margin-bottom">
							<label class="col col-sm-4 text-right form-label no-padding-left">入库日期:</label>
							<div class="col col-sm-8 col-xs-6 no-padding-left input-daterange input-group">
			                    <input type="text" class="input-sm form-control"  name="filter_ged_instockDate__FontalInstockExample" value="<fmt:formatDate value='${filter_ged_instockDate}' pattern='yyyy-MM-dd'/>" />
                                <span class="input-group-addon">到</span>
                                <input type="text" class="input-sm form-control"  name="filter_led_instockDate__FontalInstockExample" value="<fmt:formatDate value='${filter_led_instockDate}' pattern='yyyy-MM-dd'/>"/>
			                </div>
						</div>

js的配置也相对简单,在初始化的时候做一下配置,这样就可以了

$(".input-daterange").datepicker({keyboardNavigation:!1,forceParse:!1,autoclose:!0});

从下图实例可以看出,日历中有个选中的日期,前后两个日期的前后大小,由控件本身完成,不需要人为做什么操作了.
5

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

warrah

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值