0

我遇到以下问题:我有一个绑定到<input>字段的 jQuery 日期选择器。我想要的是,而不是在输入字段“MM/dd/yyyy”中显示标准日期,以便能够显示当前所选日期的一周的开始和结束,例如

如果选择了 2012 年 12 月 25 日,那么在输入字段中我想显示“Dec.24 - Dec.30”

计算开始/结束工作日和文本格式不是问题,我已经有了。我遇到的问题是尝试将输入字段的值设置为自定义文本表示时使用

$("#datepickerInput").val('custom text')

然后将 datepicker 日期设置为今天的日期,而不是保留其先前设置的值。

有没有办法以某种方式实现这一目标?

谢谢

4

3 回答 3

2

这是一个使用 moment.js 日期库来调整日期和输出格式的解决方案。当使用具有许多方法来比较、减去、添加和操作格式的库时,解析日期要容易得多。

 $("#datepicker").datepicker().change(function() {
    var d = $(this).datepicker('getDate');
    $(this).val(formatDatePickerDisplay(d))
})
/* trigger change to update display on page load*/
.change();


function formatDatePickerDisplay(d) {   
    if (!d) {
        return '';
    }
    var currDate = moment(d),
        monday = moment(currDate).day(1).format('MMM D'),
        friday = moment(currDate).day(5).format('MMM D');

    return monday + ' - ' + friday;

}

演示:http: //jsfiddle.net/7tTnV/3/

Moment.js 文档:http ://momentjs.com/docs/#/use-it/

编辑:到目前为止提供的两种解决方案的唯一问题是datepicker无法将显示的值解析为当前日期以在您打开它时突出显示。显示 datepiacker 的替代方法允许您更新将显示给用户的替代字段,并且不会显示实际的日期选择器输入。这将允许正确的当前日期突出显示

于 2012-12-25T18:51:58.263 回答
1

试试这个:

var d = $('#datepickerInput').datepicker('getDate');
$('#datepickerInput').val(getMonday(d) + ' - ' + getSunday(d));

在这里演示

于 2012-12-25T18:17:57.053 回答
1

在这里演示:http: //jsfiddle.net/2h7Sj/

我从@Palash借用了一些getMonday和逻​​辑(但修复了一个错误)。getSunday

此解决方案允许您选择特定日期选择日期范围。

HTML

<input type="text" id="dateRange" />
<input type="hidden" id="hiddenDate" />​

JavaScript

$('#dateRange').datepicker({
    altField: '#hiddenDate',
    firstDay: 1,
    onSelect: function(dateText, dateRange) {
        var dateRange = $(dateRange);

        var months       = ["Jan", "Feb", "Mar", "Apr", "May", "Jun",
                            "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"],
            hiddenDate = $('#hiddenDate'),
            theDate = new Date(dateText),
            dayOfTheWeek = theDate.getDay(),
            mondayOffset = theDate.getDate() - dayOfTheWeek + (dayOfTheWeek == 0 ? -6 : 1),
            sundayOffset = theDate.getDate() - dayOfTheWeek + (dayOfTheWeek == 0 ? 0 : 7),
            monday       = new Date(theDate.setDate(mondayOffset)),
            sunday       = new Date(theDate.setDate(sundayOffset)),
            mondayText   = months[monday.getMonth()] + '. ' + monday.getDate(),
            sundayText   = months[sunday.getMonth()] + '. ' + sunday.getDate(),
            rangeText    = mondayText + ' - ' + sundayText;

        $(this).val(rangeText);
        $(dateRange).data('rangetext', rangeText);
    },
    beforeShow: function(dateRange) {
        var hiddenDate = $('#hiddenDate');
        $(dateRange).val(hiddenDate.val());
    },
    onClose: function(selectedDateText, dateRange) {
        dateRange = $(dateRange);

        if($(this).val() == '') {
            $('#hiddenDate').val('');
        } else {
            if(selectedDateText.indexOf('-') < 0 && dateRange.data('rangetext')) {
                console.log('data-rangetext', dateRange.data('rangetext'));
                $(this).val(dateRange.data('rangetext'));
            }
        }
    }
});​
于 2012-12-26T18:35:51.603 回答