javascript - 带有 json 数据源的 jQuery UI Datepicker 中的事件

标签 javascript jquery json jquery-ui jquery-ui-datepicker

我想在 jQuery UI Datepicker 中显示事件。我希望有事件的日子的样式与没有事件的日子不同,并且我想在悬停带有事件的日期时显示带有事件详细信息的自定义工具提示。

问题“jQuery UI Datepicker with jQuery tipsy”的解决方案非常接近,但不适用于我使用的 Datepicker 配置。我使用“showOtherMonths”选项,它会关闭日期链接计算。

事件数据可在 http://mydomain.com/events.json 获得。

我想要的模型:

Datepicker with events

这是我用来创建日期选择器的代码:

$('#dateDiv').datepicker({
    altField: '#dateInput',
    altFormat: 'yy-mm-dd',
    dateFormat: 'yy-mm-dd',
    firstDay: '1',
    showOtherMonths: 'true',
});

目前我不关心解决方案的 CSS 部分,只关心 javascript 部分。悬停带有附加事件的日期时,如何显示我的自定义工具提示?以及如何附加事件(日历事件,而不是 javascript/DOM 事件;))?

最佳答案

这不是一个非常优雅的解决方案,但它似乎确实有效。有人能想出更好的办法吗?

编辑:这是运行代码的jsFiddle:http://jsfiddle.net/Tobbe/JrkSN/3/

EDIT2: 它一直有效,直到我点击一个日期,然后所有事件都消失了,因为在这种情况下不会调用 beforeShowDay 回调。我该如何解决这个问题?

getEvents();

$(function() {
    $('#dateDiv').datepicker({
        altField: '#dateInput',
        altFormat: 'yy-mm-dd',
        dateFormat: 'yy-mm-dd',
        firstDay: '1',
        showOtherMonths: 'true',
        beforeShowDay: beforeShowDay,
        onChangeMonthYear: getEvents
    });
});

var enqueuedDates = [];
var tryCounter = 0;
var events = [];

function getEvents() {
    events = [];
    enqueuedDates = [];
    $.getJSON('events.json', function(json) {
        events = json;
    });
}

function beforeShowDay(date) {
    enqueuedDates.push(new Date(date));

    if (enqueuedDates.length == 35) {
        processEnqueuedDates();
    }

    return [true, '', ''];
}

function processEnqueuedDates() {
    if (!events || events.length === 0) {
        tryCounter++;
        if (tryCounter < 100) {
            setTimeout(processEnqueuedDates, 10);
        } else {
            tryCounter = 0;
        }

        return;
    }

    tryCounter = 0;

    for (var i = 0; i < enqueuedDates.length; ++i) {
        var event = getEvent(events, enqueuedDates[i]);

        if (event) {
            var theDateCells = $('#dateDiv .ui-datepicker-calendar td');
            var hideTimeoutID;
            theDateCells.eq(i).addClass('eventPlanned').
                bind('mouseenter', function(eventText) {
                    return function() {
                        if (hideTimeoutID) {
                            clearTimeout(hideTimeoutID);
                            hideTimeoutID = null;
                        }

                        var popup = $('#eventPopup');
                        if (popup.size() == 0) {
                            popup = $('<div></div>').attr('id', 'eventPopup');
                            $('body').append(popup);
                        }

                        var pos = $(this).offset();

                        popup.html('<p>' + eventText + '</p>').
                            css('left', pos.left + 5 + 'px').
                            css('top', (pos.top - popup.height() - 2) + 'px').
                            bind('mouseenter', function() {
                                clearTimeout(hideTimeoutID);
                                hideTimeoutID = null;
                            }).
                            bind('mouseleave', function() {
                                $(this).hide();
                            }).
                            show();
                    }
                }(event.text)).
                bind('mouseleave', function(eventObject) {
                    hideTimeoutID = setTimeout(function() {
                        $('#eventPopup').hide();
                    }, 200);
                });
        }
    }
}

function getEvent(events, date) {
    return events.filter(function(event, index, arr) {
        return date - $.datepicker.parseDate('yy-mm-dd', event.date) === 0;
    })[0];
}

关于javascript - 带有 json 数据源的 jQuery UI Datepicker 中的事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4017897/

相关文章:

javascript - 自定义网络字体

javascript - 对 <xsl :template> 中的 <div> 的引用

javascript - 使用 JQuery 设置默认语言

javascript - 等待用户点击而不是页面加载来启动功能

c# - 在 Monotouch 中将 IEnumerable<T> 简单转换为 JSON

javascript - 将 JSON 文件转换为 Javascript 对象

javascript - 指令就像棱 Angular Material 的底片

javascript - 在模式窗口 MVC4 上显示下拉列表

jquery - 如何在jquery中读取ViewBag列表

c# - 我如何使用 Json.NET 反序列化 PropertyInfo?