x-editable datepicker仅限年/月

时间:2014-05-30 03:34:12

标签: javascript jquery-ui jquery-ui-datepicker x-editable

我已将jQuery UI datepicker修改为仅显示年份和月份。我使用这些javascript事件来处理数据:http://jsfiddle.net/2puz2/4/

$( "#datepicker" ).datepicker({
    showButtonPanel: true,
    changeMonth: true,
    changeYear: true,
    dateFormat: 'yy-mm',
    currentText: 'This Month',
    onClose: function(dateText, inst) {
        var month = $('#ui-datepicker-div .ui-datepicker-month :selected').val();
        var year = $('#ui-datepicker-div .ui-datepicker-year :selected').val();
        $(this).datepicker('setDate', new Date(year, month, 1));
        var setMonth = ('0' + (parseInt(month) + 1)).slice(-2);
        $(this).val('Start: ' +  year + '-' + setMonth);
    },
    beforeShow: function(input, inst) {
        if ((datestr = $(this).val()).length > 0) {
            var dateOutOfDesc = datestr.match(/\d{4}\-\d{2}/);
            var dateparts = dateOutOfDesc[0].split('-');
            var year = dateparts[0];
            var month = dateparts[1];
            $(this).datepicker('option', 'defaultDate', new Date(year, month-1, 1));
            $(this).datepicker('setDate', new Date(year, month-1, 1));
        }
    }
});

现在我想使用x-editable来编辑这个日期,但我无法弄清楚如何将这些回调函数附加到内置的datepicker。我试过了

editable.input.options.datepicker.beforeShow = function(input, inst) {
...

请参阅此http://jsfiddle.net/L2Z9Q/18/

但似乎这是在datepicker已经初始化之后。

有什么想法吗?

1 个答案:

答案 0 :(得分:3)

您应该使用onChangeMonthYear事件(在月份或年份更改时触发 - docs)来更新日期选择日期而不是onClose。我没有解释为什么onClose没有被解雇......

$('#yearmonth').editable({
    pk: 1,
    format: 'yyyy-mm',    
    viewformat: 'yyyy-mm',    
    datepicker: {            
        onChangeMonthYear: function(  year,  month,  inst){
            $(this).datepicker('setDate', new Date(year, month-1, 1));
        }
    }
})

Fiddle