我想在 jQuery UI Datepicker 中显示事件。我希望有事件的日子的样式与没有事件的日子不同,并且我想在悬停带有事件的日期时显示带有事件详细信息的自定义工具提示。
问题“jQuery UI Datepicker with jQuery tipsy”的解决方案非常接近,但不适用于我使用的 Datepicker 配置。我使用“showOtherMonths”选项,它会关闭日期链接计算。
事件数据可在 http://mydomain.com/events.json 获得。
我想要的模型:
这是我用来创建日期选择器的代码:
$('#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/