js 是实现网页日期控件
2009-07-03 14:18
357 查看
var calenderMonth = 0; function JCalendar(year, month, date) { var _date = arguments.length == 0 ? new Date() : new Date(year, month - 1, date); this.year = _date.getFullYear(); this.month = _date.getMonth() + 1; this.fday = new Date(this.year, this.month - 1, 1).getDay(); this.dayNum = new Date(this.year, this.month, 0).getDate(); JCalendar.cur_year = this.year; JCalendar.cur_month = this.month; JCalendar.cur_date = _date.getDate(); } JCalendar.prototype.show = function() { var date = new Array(this.fday > 0 ? this.day: 0); var html_str = new Array(); var date_index = 0; var weekDay = ["日", "一", "二", "三", "四", "五", "六"]; for (var j = 1; j <= this.dayNum; j++) { date.push(j); } html_str.push("
"); html_str.push("
" + "" + "
"); html_str.push(""); for (var i = 0; i < 7; i++) { html_str.push(""); } html_str.push(""); for (var i = 0; i < 6; i++) { html_str.push(""); for (var j = 0; j < 7; j++) { tmp = date[date_index++]; tmp = tmp ? tmp: ""; if (JCalendar.cur_date == tmp) { html_str.push("
" + JCalendar.cur_date + "
"); } else if (tmp == "") { html_str.push(" "); } else { html_str.push("" + tmp + ""); } } html_str.push(""); } html_str.push("
"); return html_str.join(""); }; JCalendar.update = function(_month) { calenderMonth = _month; var date = new Date(JCalendar.cur_year, JCalendar.cur_month - 1 + _month, 1); var fday = date.getDay(); var year = date.getFullYear(); var month = date.getMonth() + 1; var dayNum = new Date(JCalendar.cur_year, JCalendar.cur_month + _month, 0).getDate(); var tds = document.getElementById("calendar").getElementsByTagName("dd"); for (var i = 7; i < tds.length; i++) { tds[i].innerHTML = ""; tds[i].className = "none"; }; var my_calendar_month = ""; for (var m = 1; m < 13; m++) { my_calendar_month = my_calendar_month + "date.getFullYear() - 10; y--) { my_calendar_year = my_calendar_year + "" + j + ""; tds[6 + fday + j].className = ""; } JCalendar.onupdate(year, month, JCalendar.cur_date); }; JCalendar.onupdate = function(year, month, date) { if (calenderMonth != 0) { /**/ } }; JCalendar.click = function(obj) { var tmp = document.getElementById("cal_today"); tmp.parentNode.innerHTML = "" + tmp.innerHTML + ""; JCalendar.cur_date = parseInt(obj.innerHTML); obj.innerHTML = "" + obj.innerHTML + ""; JCalendar.onclick(JCalendar.cur_year, JCalendar.cur_month, JCalendar.cur_date); }; JCalendar.onclick = function(year, month, date) { /*点击日期时执行的函数,可以更改为自己需要函数,控件传递过来的参数为当前日期*/ alert("您选择的是" + year + "年" + month + "月" + date + "日,改时执行的函数,可以更改为自己需要函数,请修改js文件"); }; function showcalendar() { document.getElementById('calendardiv').style.display = ''; document.getElementById('calendardiv').innerHTML = new JCalendar().show(); JCalendar.update(0); }
"); html_str.push("
" + "" + "
"); html_str.push(""); for (var i = 0; i < 7; i++) { html_str.push(""); } html_str.push(""); for (var i = 0; i < 6; i++) { html_str.push(""); for (var j = 0; j < 7; j++) { tmp = date[date_index++]; tmp = tmp ? tmp: ""; if (JCalendar.cur_date == tmp) { html_str.push("
" + JCalendar.cur_date + "
"); } else if (tmp == "") { html_str.push(" "); } else { html_str.push("" + tmp + ""); } } html_str.push(""); } html_str.push("
"); return html_str.join(""); }; JCalendar.update = function(_month) { calenderMonth = _month; var date = new Date(JCalendar.cur_year, JCalendar.cur_month - 1 + _month, 1); var fday = date.getDay(); var year = date.getFullYear(); var month = date.getMonth() + 1; var dayNum = new Date(JCalendar.cur_year, JCalendar.cur_month + _month, 0).getDate(); var tds = document.getElementById("calendar").getElementsByTagName("dd"); for (var i = 7; i < tds.length; i++) { tds[i].innerHTML = ""; tds[i].className = "none"; }; var my_calendar_month = ""; for (var m = 1; m < 13; m++) { my_calendar_month = my_calendar_month + "date.getFullYear() - 10; y--) { my_calendar_year = my_calendar_year + "" + j + ""; tds[6 + fday + j].className = ""; } JCalendar.onupdate(year, month, JCalendar.cur_date); }; JCalendar.onupdate = function(year, month, date) { if (calenderMonth != 0) { /**/ } }; JCalendar.click = function(obj) { var tmp = document.getElementById("cal_today"); tmp.parentNode.innerHTML = "" + tmp.innerHTML + ""; JCalendar.cur_date = parseInt(obj.innerHTML); obj.innerHTML = "" + obj.innerHTML + ""; JCalendar.onclick(JCalendar.cur_year, JCalendar.cur_month, JCalendar.cur_date); }; JCalendar.onclick = function(year, month, date) { /*点击日期时执行的函数,可以更改为自己需要函数,控件传递过来的参数为当前日期*/ alert("您选择的是" + year + "年" + month + "月" + date + "日,改时执行的函数,可以更改为自己需要函数,请修改js文件"); }; function showcalendar() { document.getElementById('calendardiv').style.display = ''; document.getElementById('calendardiv').innerHTML = new JCalendar().show(); JCalendar.update(0); }
相关文章推荐
- 收集几个js实现的日期时间控件
- 前台技术--js实现日期控件
- JS写的一个日期选择控件(移动网页的),写得不当的地方,望各位大神指正
- js实现的日期控件
- 能实现点击日期把日期赋值给文本框的js日历控件
- js实现日期控件
- js实现jsp页面日期时间控件
- 利用JS实现Web日历控件(包括日期和时间)
- JS实现网页标题栏显示当前时间和日期的完整代码
- 一个用jS实现的日期控件
- (很好用)JS时间控件实现日期的多选
- js实现网页和控件的简单交互
- JS实现网页标题栏显示当前时间和日期的完整代码
- 网页纯JS日期时间控件
- JS验证日期的格式YYYY-mm-dd 具体实现
- 一个JS图片放大镜,实现动态记录的图片放大,避免内存泄露,解决IE6下无法遮盖select控件问题
- javascript控制服务器控件-js操作CheckBoxList实现全选、反选
- ASP(JS)—日期时间控件
- js实现网页在线聊天功能(二)
- javascript 日期时间控件 js代码