jquery日历控件

最近弄了个简单jquery的日历控件,拿出来分享一下,先看效果图:


大家可以到下面的链接下载源文件代码:


http://download.csdn.net/detail/sunjava1/7466265


下面粘贴代码,先来主要的js

DateInput = (function($) {
	function DateInput(el, opts) {
		if (typeof(opts) != "object") opts = {};
		$.extend(this, DateInput.DEFAULT_OPTS, opts);
		this.input = $(el);
		this.bindMethodsToObj("show", "hide", "hideIfClickOutside", "keydownHandler", "selectDate");
		this.build();
		this.selectDate();
		this.hide()
	};
	DateInput.DEFAULT_OPTS = {
		month_names: ["一月份", "二月份", "三月份", "四月份", "五月份", "六月份", "七月份", "八月份", "九月份", "十月份", "十一月份", "十二月份"],
		short_month_names: ["1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12"],
		short_day_names: ["日", "一", "二", "三", "四", "五", "六"],
		start_of_week: 1
	};
	DateInput.prototype = {
		build: function() {
			var monthNav = $('<p class="month_nav">' + '<span class="button prev" title="[Page-Up]">«</span>' + ' <span class="month_name"></span> ' + '<span class="button next" title="[Page-Down]">»</span>' + '</p>');
			this.monthNameSpan = $(".month_name", monthNav);
			$(".prev", monthNav).click(this.bindToObj(function() {
				this.moveMonthBy( - 1)
			}));
			$(".next", monthNav).click(this.bindToObj(function() {
				this.moveMonthBy(1)
			}));
			var yearNav = $('<p class="year_nav">' + '<span class="button prev" title="[Ctrl+Page-Up]">«</span>' + ' <span class="year_name"></span> ' + '<span class="button next" title="[Ctrl+Page-Down]">»</span>' + '</p>');
			this.yearNameSpan = $(".year_name", yearNav);
			$(".prev", yearNav).click(this.bindToObj(function() {
				this.moveMonthBy( - 12)
			}));
			$(".next", yearNav).click(this.bindToObj(function() {
				this.moveMonthBy(12)
			}));
			var nav = $('<div class="nav"></div>').append(monthNav, yearNav);
			var tableShell = "<table><thead><tr>";
			$(this.adjustDays(this.short_day_names)).each(function() {
				tableShell += "<th>" + this + "</th>"
			});
			tableShell += "</tr></thead><tbody></tbody></table>";
			this.dateSelector = this.rootLayers = $('<div class="date_selector"></div>').append(nav, tableShell).insertAfter(this.input);
			if ($.browser.msie && $.browser.version < 7) {
				this.ieframe = $('<iframe class="date_selector_ieframe" frameborder="0" src="#"></iframe>').insertBefore(this.dateSelector);
				this.rootLayers = this.rootLayers.add(this.ieframe);
				$(".button", nav).mouseover(function() {
					$(this).addClass("hover")
				});
				$(".button", nav).mouseout(function() {
					$(this).removeClass("hover")
				})
			};
			this.tbody = $("tbody", this.dateSelector);
			this.input.change(this.bindToObj(function() {
				this.selectDate()
			}));
			this.selectDate()
		},
		selectMonth: function(date) {
			var newMonth = new Date(date.getFullYear(), date.getMonth(), 1);
			if (!this.currentMonth || !(this.currentMonth.getFullYear() == newMonth.getFullYear() && this.currentMonth.getMonth() == newMonth.getMonth())) {
				this.currentMonth = newMonth;
				var rangeStart = this.rangeStart(date),
				rangeEnd = this.rangeEnd(date);
				var numDays = this.daysBetween(rangeStart, rangeEnd);
				var dayCells = "";
				for (var i = 0; i <= numDays; i++) {
					var currentDay = new Date(rangeStart.getFullYear(), rangeStart.getMonth(), rangeStart.getDate() + i, 12, 00);
					if (this.isFirstDayOfWeek(currentDay)) dayCells += "<tr>";
					if (currentDay.getMonth() == date.getMonth()) {
						dayCells += '<td class="selectable_day" date="' + this.dateToString(currentDay) + '">' + currentDay.getDate() + '</td>'
					} else {
						dayCells += '<td class="unselected_month" date="' + this.dateToString(currentDay) + '">' + currentDay.getDate() + '</td>'
					};
					if (this.isLastDayOfWeek(currentDay)) dayCells += "</tr>"
				};
				this.tbody.empty().append(dayCells);
				this.monthNameSpan.empty().append(this.monthName(date));
				this.yearNameSpan.empty().append(this.currentMonth.getFullYear());
				$(".selectable_day", this.tbody).click(this.bindToObj(function(event) {
					this.changeInput($(event.target).attr("date"))
				}));
				$("td[date=" + this.dateToString(new Date()) + "]", this.tbody).addClass("today");
				$("td.selectable_day", this.tbody).mouseover(function() {
					$(this).addClass("hover")
				});
				$("td.selectable_day", this.tbody).mouseout(function() {
					$(this).removeClass("hover")
				})
			};
			$('.selected', this.tbody).removeClass("selected");
			$('td[date=' + this.selectedDateString + ']', this.tbody).addClass("selected")
		},
		selectDate: function(date) {
			if (typeof(date) == "undefined") {
				date = this.stringToDate(this.input.val())
			};
			if (!date) date = new Date();
			this.selectedDate = date;
			this.selectedDateString = this.dateToString(this.selectedDate);
			this.selectMonth(this.selectedDate)
		},
		changeInput: function(dateString) {
			this.input.val(dateString).change();
			this.hide()
		},
		show: function() {
			this.rootLayers.css("display", "block");
			$([window, document.body]).click(this.hideIfClickOutside);
			this.input.unbind("focus", this.show);
			$(document.body).keydown(this.keydownHandler);
			this.setPosition()
		},
		hide: function() {
			this.rootLayers.css("display", "none");
			$([window, document.body]).unbind("click", this.hideIfClickOutside);
			this.input.focus(this.show);
			$(document.body).unbind("keydown", this.keydownHandler)
		},
		hideIfClickOutside: function(event) {
			if (event.target != this.input[0] && !this.insideSelector(event)) {
				this.hide()
			}
		},
		insideSelector: function(event) {
			var offset = this.dateSelector.position();
			offset.right = offset.left + this.dateSelector.outerWidth();
			offset.bottom = offset.top + this.dateSelector.outerHeight();
			return event.pageY < offset.bottom && event.pageY > offset.top && event.pageX < offset.right && event.pageX > offset.left
		},
		keydownHandler: function(event) {
			switch (event.keyCode) {
			case 9:
			case 27:
				this.hide();
				return;
				break;
			case 13:
				this.changeInput(this.selectedDateString);
				break;
			case 33:
				this.moveDateMonthBy(event.ctrlKey ? -12 : -1);
				break;
			case 34:
				this.moveDateMonthBy(event.ctrlKey ? 12 : 1);
				break;
			case 38:
				this.moveDateBy( - 7);
				break;
			case 40:
				this.moveDateBy(7);
				break;
			case 37:
				this.moveDateBy( - 1);
				break;
			case 39:
				this.moveDateBy(1);
				break;
			default:
				return
			}
			event.preventDefault()
		},
		stringToDate: function(string) {
			var matches;
			if (matches = string.match(/^(\d{1,2}) ([^\s]+) (\d{4,4})$/)) {
				return new Date(matches[3], this.shortMonthNum(matches[2]), matches[1], 12, 00)
			} else {
				return null
			}
		},
		dateToString: function(date) {
			return date.getFullYear()+"-"+this.short_month_names[date.getMonth()]+"-" +date.getDate()
		},
		setPosition: function() {
			var offset = this.input.offset();
			this.rootLayers.css({
				top: offset.top + this.input.outerHeight(),
				left: offset.left
			});
			if (this.ieframe) {
				this.ieframe.css({
					width: this.dateSelector.outerWidth(),
					height: this.dateSelector.outerHeight()
				})
			}
		},
		moveDateBy: function(amount) {
			var newDate = new Date(this.selectedDate.getFullYear(), this.selectedDate.getMonth(), this.selectedDate.getDate() + amount);
			this.selectDate(newDate)
		},
		moveDateMonthBy: function(amount) {
			var newDate = new Date(this.selectedDate.getFullYear(), this.selectedDate.getMonth() + amount, this.selectedDate.getDate());
			if (newDate.getMonth() == this.selectedDate.getMonth() + amount + 1) {
				newDate.setDate(0)
			};
			this.selectDate(newDate)
		},
		moveMonthBy: function(amount) {
			var newMonth = new Date(this.currentMonth.getFullYear(), this.currentMonth.getMonth() + amount, this.currentMonth.getDate());
			this.selectMonth(newMonth)
		},
		monthName: function(date) {
			return this.month_names[date.getMonth()]
		},
		bindToObj: function(fn) {
			var self = this;
			return function() {
				return fn.apply(self, arguments)
			}
		},
		bindMethodsToObj: function() {
			for (var i = 0; i < arguments.length; i++) {
				this[arguments[i]] = this.bindToObj(this[arguments[i]])
			}
		},
		indexFor: function(array, value) {
			for (var i = 0; i < array.length; i++) {
				if (value == array[i]) return i
			}
		},
		monthNum: function(month_name) {
			return this.indexFor(this.month_names, month_name)
		},
		shortMonthNum: function(month_name) {
			return this.indexFor(this.short_month_names, month_name)
		},
		shortDayNum: function(day_name) {
			return this.indexFor(this.short_day_names, day_name)
		},
		daysBetween: function(start, end) {
			start = Date.UTC(start.getFullYear(), start.getMonth(), start.getDate());
			end = Date.UTC(end.getFullYear(), end.getMonth(), end.getDate());
			return (end - start) / 86400000
		},
		changeDayTo: function(dayOfWeek, date, direction) {
			var difference = direction * (Math.abs(date.getDay() - dayOfWeek - (direction * 7)) % 7);
			return new Date(date.getFullYear(), date.getMonth(), date.getDate() + difference)
		},
		rangeStart: function(date) {
			return this.changeDayTo(this.start_of_week, new Date(date.getFullYear(), date.getMonth()), -1)
		},
		rangeEnd: function(date) {
			return this.changeDayTo((this.start_of_week - 1) % 7, new Date(date.getFullYear(), date.getMonth() + 1, 0), 1)
		},
		isFirstDayOfWeek: function(date) {
			return date.getDay() == this.start_of_week
		},
		isLastDayOfWeek: function(date) {
			return date.getDay() == (this.start_of_week - 1) % 7
		},
		adjustDays: function(days) {
			var newDays = [];
			for (var i = 0; i < days.length; i++) {
				newDays[i] = days[(i + this.start_of_week) % 7]
			};
			return newDays
		}
	};
	$.fn.date_input = function(opts) {
		return this.each(function() {
			new DateInput(this, opts)
		})
	};
	$.date_input = {
		initialize: function(opts) {
			$("input.date_input").date_input(opts)
		}
	};
	return DateInput
})(jQuery);

再来css样式文件:

.date_selector, .date_selector *{width: auto;height: auto;border: none;background: none;margin: 0;padding: 0;
text-align: left;text-decoration: none;}
.date_selector{background:#fbfbfb;border: 1px solid #ccc;padding: 10px;margin:0;margin-top:-1px;
position: absolute;z-index:100000;display:none;border-radius: 3px;box-shadow: 0 0 5px #aaa;box-shadow:0 2px 2px #ccc; width:180px;}
.date_selector_ieframe{position: absolute;z-index: 99999;display: none;}
.date_selector .nav{width: 11.0em;}
.date_selector .nav p{clear: none;}
.date_selector .month_nav,.date_selector .year_nav
{
margin: 0 0 1px 0;
padding: 0;
display: block;
position: relative;
text-align: center;
}
.date_selector .month_nav{float: left;width: 50%;}
.date_selector .year_nav{float: right;width: 50%;margin-right: -8px;}
.date_selector .month_name, .date_selector .year_name{font-weight: bold;font-size:13px;line-height: 20px;}
.date_selector .button{display: block;position: absolute;
top: 0;width:18px;height:18px;line-height:16px;font-weight:bold;color:#5985c7;
text-align: center;font-size:12px;overflow:hidden;border: 1px solid #ccc;border-radius:2px;}
.date_selector .button:hover, .date_selector .button.hover{background:#5985c7;color: #fff;
cursor: pointer;border-color:#3a930d;}
.date_selector .prev{left: 0;}
.date_selector .next{right: 0;}
.date_selector table{border-spacing: 0;border-collapse: collapse;clear: both;margin: 0; width:180px;}
.date_selector th, .date_selector td{width: 2.0em;height: 1.0em;padding: 0 !important;text-align: center !important;
color: #666;font-weight: normal;}
.date_selector th{font-size: 12px;}
.date_selector td{border:1px solid #f1f1f1;line-height: 2em;text-align: center;
white-space: nowrap;color:#5985c7;background:#fff;}
.date_selector td.today{background: #eee;}
.date_selector td.unselected_month{color: #ccc;}
.date_selector td.selectable_day{cursor: pointer;background:#E8FFEF}
.date_selector td.selected{background:#2b579a;color: #fff;font-weight: bold;}
.date_selector td.selectable_day:hover,.date_selector td.selectable_day .hover{background:#5985c7;color: #fff;}
<span style="font-size:18px;"><strong>最后如何使用:</strong></span>
<pre name="code" class="html"><BODY>
 <!--日历使用-->
  Date:<input type="text" class="date_picker">
  <!--初始化日历组件一定要在日历文本框之后-->
   <script language="javascript" type="text/javascript">
	 $('.date_picker').date_input();
  </script>

 </BODY>

好了大功告成!大家可以到下面的链接下载源文件代码:

http://download.csdn.net/detail/sunjava1/7466265

 
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值