/**
* 完整代码
*/
// 关于月份: 在设置时要-1,使用时要+1
$(function() {
$('#calendar').on('click', function() {
// return false;
})
$('#calendar').calendar({
ifSwitch: true, // 是否切换月份
hoverDate: false, // hover是否显示当天信息
backToday: true // 是否返回当天
});
});
;
(function($, window, document, undefined) {
var Calendar = function(elem, options) {
this.$calendar = elem;
this.defaults = {
ifSwitch: true,
hoverDate: false,
backToday: false
};
this.opts = $.extend({}, this.defaults, options);
// console.log(this.opts);
};
Calendar.prototype = {
showHoverInfo: function(obj) { // hover 时显示当天信息
var _dateStr = $(obj).attr('data');
var offset_t = $(obj).offset().top + (this.$calendar_today.height() - $(obj).height()) / 2;
var offset_l = $(obj).offset().left + $(obj).width();
var changeStr = addMark(_dateStr);
var _week = changingStr(changeStr).getDay();
var _weekStr = '';
// this.$calendar_today.show();
this.$calendar_today
.css({ left: offset_l, top: offset_t })
.stop()
.animate({ left: offset_l, top: offset_t });
switch (_week) {
case 0:
_weekStr = 'Sunday';
break;
case 1:
_weekStr = 'Monday';
break;
case 2:
_weekStr = 'Tuesday';
break;
case 3:
_weekStr = 'Wednesday';
break;
case 4:
_weekStr = 'Thursday';
break;
case 5:
_weekStr = 'Friday';
break;
case 6:
_weekStr = 'Saturday';
break;
}
this.$calendarToday_date.text(changeStr);
this.$calendarToday_week.text(_weekStr);
},
showCalendar: function() { // 输入数据并显示
var self = this;
var year = dateObj.getDate().getFullYear();
var month = dateObj.getDate().getMonth() + 1;
var dateStr = returnDateStr(dateObj.getDate());
var firstDay = new Date(year, month - 1, 1); // 当前月的第一天
this.$calendarTitle_text.text(year + '/' + dateStr.substr(4, 2));
this.$calendarDate_item.each(function(i) {
// allDay: 得到当前列表显示的所有天数
var allDay = new Date(year, month - 1, i + 1 - firstDay.getDay());
var allDay_str = returnDateStr(allDay);
$(this).text(allDay.getDate()).attr('data', allDay_str);
if (returnDateStr(new Date()) === allDay_str) {
$(this).attr('class', 'item item-curDay');
} else if (returnDateStr(firstDay).substr(0, 6) === allDay_str.substr(0, 6)) {
$(this).attr('class', 'item item-curMonth');
} else {
$(this).attr('class', 'item');
}
});
// 已选择的情况下,切换日期也不会改变
if (self.selected_data) {
var selected_elem = self.$calendar_date.find('[data=' + self.selected_data + ']');
selected_elem.addClass('item-selected');
}
},
renderDOM: function() { // 渲染DOM
this.$calendar_title = $('
');
this.$calendar_week = $('');
this.$calendar_date = $('');
this.$calendar_today = $('');
var _titleStr = '' +
'T' +
'' +
'<' +
'>' +
'
';
var _weekStr = '日' +
'一' +
'二' +
'三' +
'四' +
'五' +
'六';
var _dateStr = '';
var _dayStr = '' +
'' +
'';
for (var i = 0; i < 6; i++) {
_dateStr += '26' +
'26' +
'26' +
'26' +
'26' +
'26' +
'26';
}
this.$calendar_title.html(_titleStr);
this.$calendar_week.html(_weekStr);
this.$calendar_date.html(_dateStr);
this.$calendar_today.html(_dayStr);
this.$calendar.append(this.$calendar_title, this.$calendar_week, this.$calendar_date, this.$calendar_today);
this.$calendar.show();
},
inital: function() { // 初始化
var self = this;
this.renderDOM();
this.$calendarTitle_text = this.$calendar_title.find('.title');
this.$backToday = $('#backToday');
this.$arrow_prev = this.$calendar_title.find('.arrow-prev');
this.$arrow_next = this.$calendar_title.find('.arrow-next');
this.$calendarDate_item = this.$calendar_date.find('.item');
this.$calendarToday_date = this.$calendar_today.find('.date');
this.$calendarToday_week = this.$calendar_today.find('.week');
this.selected_data = 0;
this.showCalendar();
if (this.opts.ifSwitch) {
this.$arrow_prev.bind('click', function(e) {
var _date = dateObj.getDate();
dateObj.setDate(new Date(_date.getFullYear(), _date.getMonth() - 1, 1));
self.showCalendar();
return false;
});
this.$arrow_next.bind('click', function() {
var _date = dateObj.getDate();
dateObj.setDate(new Date(_date.getFullYear(), _date.getMonth() + 1, 1));
self.showCalendar();
return false;
});
}
if (this.opts.backToday) {
var cur_month = dateObj.getDate().getMonth() + 1;
this.$backToday.bind('click', function() {
var item_month = $('.item-curMonth').eq(0).attr('data').substr(4, 2);
var if_lastDay = (item_month != cur_month) ? true : false;
if (!self.$calendarDate_item.hasClass('item-curDay') || if_lastDay) {
dateObj.setDate(new Date());
self.showCalendar();
}
});
}
this.$calendarDate_item.hover(function() {
self.showHoverInfo($(this));
}, function() {
self.$calendar_today.css({ left: 0, top: 0 }).hide();
});
this.$calendarDate_item.click(function() {
var _dateStr = $(this).attr('data');
var _date = changingStr(addMark(_dateStr));
var $curClick = null;
self.selected_data = $(this).attr('data');
dateObj.setDate(new Date(_date.getFullYear(), _date.getMonth(), 1));
if (!$(this).hasClass('item-curMonth')) {
self.showCalendar();
}
$curClick = self.$calendar_date.find('[data=' + _dateStr + ']');
$curDay = self.$calendar_date.find('.item-curDay');
if (!$curClick.hasClass('item-selected')) {
self.$calendarDate_item.removeClass('item-selected');
$curClick.addClass('item-selected');
}
// console.log(_date)
var timeName = document.getElementById('timeName')
var year = _date.getFullYear();
var month = (_date.getMonth() + 1) < 10 ? '0' + (_date.getMonth() + 1) : (_date.getMonth() + 1);
var date = _date.getDate() < 10 ? '0' + _date.getDate() : _date.getDate();
var hour = _date.getHours() < 10 ? '0' + _date.getHours() : _date.getHours();
var min = _date.getMinutes() < 10 ? '0' + _date.getMinutes() : _date.getMinutes();
var second = _date.getSeconds() < 10 ? '0' + _date.getSeconds() : _date.getSeconds();
var mydate = year + '-' + month + '-' + date + ' ' + hour + ':' + min + ':' + second;
timeName.setAttribute('timedata', mydate)
timeName.innerHTML = (mydate.split(' '))[0]
$('#timeshow').text(Tool.toCH($('#timeName').text()))
ajax.loadProgram();
ajax.loadAllProgram();
// ajax.loaddata()
$('#calendarboxes').hide();
});
},
constructor: Calendar
};
$.fn.calendar = function(options) {
var calendar = new Calendar(this, options);
return calendar.inital();
};
// ========== 使用到的方法 ==========
var dateObj = (function() {
var _date = new Date();
return {
getDate: function() {
return _date;
},
setDate: function(date) {
_date = date;
}
}
})();
function returnDateStr(date) { // 日期转字符串
var year = date.getFullYear();
var month = date.getMonth() + 1;
var day = date.getDate();
month = month <= 9 ? ('0' + month) : ('' + month);
day = day <= 9 ? ('0' + day) : ('' + day);
return year + month + day;
};
function changingStr(fDate) { // 字符串转日期
var fullDate = fDate.split("-");
return new Date(fullDate[0], fullDate[1] - 1, fullDate[2]);
};
function addMark(dateStr) { // 给传进来的日期字符串加-
return dateStr.substr(0, 4) + '-' + dateStr.substr(4, 2) + '-' + dateStr.substring(6);
};
// 条件1:年份必须要能被4整除
// 条件2:年份不能是整百数
// 条件3:年份是400的倍数
function isLeapYear(year) { // 判断闰年
return (year % 4 == 0) && (year % 100 != 0 || year % 400 == 0);
}
})(jQuery, window, document);