根据一篇js日历插件改写的


  1 <!--
2 控件调用示例:
3 -->
4
5 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
6
7 <html xmlns="http://www.w3.org/1999/xhtml">
8
9 <head>
10
11 <script src="date.js" language="javascript" ></script>
12
13 </head>
14
15 <body>
16
17 <input type="text" style="width:70px" onfocus="HS_setDate(this)">
18
19
20
21
22 </body>
23
24 </html>
25
26
27 //date.js
28
29
30 function HS_DateAdd(interval,number,date){
31
32 number = parseInt(number);
33
34 if (typeof(date)=="string"){var date = new Date(date.split("-")[0],date.split("-")[1],date.split("-")[2])}
35
36 if (typeof(date)=="object"){var date = date}
37
38 switch(interval){
39
40 case "y":return new Date(date.getFullYear()+number,date.getMonth(),date.getDate()); break;
41
42 case "m":return new Date(date.getFullYear(),date.getMonth()+number,checkDate(date.getFullYear(),date.getMonth()+number,date.getDate())); break;
43
44 case "d":return new Date(date.getFullYear(),date.getMonth(),date.getDate()+number); break;
45
46 case "w":return new Date(date.getFullYear(),date.getMonth(),7*number+date.getDate()); break;
47
48 }
49
50 }
51
52 function checkDate(year,month,date){
53
54 var enddate = ["31","28","31","30","31","30","31","31","30","31","30","31"];
55
56 var returnDate = "";
57
58 if (year%4==0){enddate[1]="29"}
59
60 if (date>enddate[month]){returnDate = enddate[month]}else{returnDate = date}
61
62 return returnDate;
63
64 }
65
66 function WeekDay(date){
67
68 var theDate;
69
70 if (typeof(date)=="string"){theDate = new Date(date.split("-")[0],date.split("-")[1],date.split("-")[2]);}
71
72 if (typeof(date)=="object"){theDate = date}
73
74 return theDate.getDay();
75
76 }
77
78 function HS_calender(){
79
80 var lis = "";
81
82 var style = "";
83
84
85
86 style +="<style type=‘text/css‘>";
87
88 style +=".calender { width:170px; height:auto; font-size:12px; margin-right:14px; background:url(calenderbg.gif) no-repeat right center #fff; border:1px solid #397EAE; padding:1px;z-index:10009;}";
89
90 style +=".calender ul {list-style-type:none; margin:0; padding:0;}";
91
92 style +=".calender .day { background-color:#EDF5FF; height:20px;}";
93
94 style +=".calender .day li,.calender .date li{ float:left; width:14%; height:20px; line-height:20px; text-align:center}";
95
96 style +=".calender li a { text-decoration:none; font-family:Tahoma; font-size:11px; color:#333}";
97
98 style +=".calender li a:hover { color:#f30; text-decoration:underline}";
99
100 style +=".calender li a.hasArticle {font-weight:bold; color:#f60 !important}";
101
102 style +=".lastMonthDate, .nextMonthDate {color:#bbb;font-size:11px}";
103
104 style +=".selectThisYear a, .selectThisMonth a{text-decoration:none; margin:0 2px; color:#000; font-weight:bold}";
105
106 style +=".calender .LastMonth, .calender .NextMonth{ text-decoration:none; color:#000; font-size:18px; font-weight:bold; line-height:16px;}";
107
108 style +=".calender .LastMonth { float:left;}";
109
110 style +=".calender .NextMonth { float:right;}";
111
112 style +=".calenderBody {clear:both}";
113
114 style +=".calenderTitle {text-align:center;height:20px; line-height:20px; clear:both}";
115
116 style +=".today { background-color:#ffffaa;border:1px solid #f60; padding:2px}";
117
118 style +=".today a { color:#f30; }";
119
120 style +=".calenderBottom {clear:both; border-top:1px solid #ddd; padding: 3px 0; text-align:left;line-height:20px}";
121
122 style +=".calenderBottom a {text-decoration:none; margin:2px !important; font-weight:bold; color:#000}";
123
124 style +=".calenderBottom a.closeCalender{float:right;}";
125
126 style +=".closeCalenderBox {float:right; border:1px solid #000; background:#fff; font-size:9px; width:11px; height:11px; line-height:11px; text-align:center;overflow:hidden; font-weight:normal !important}";
127
128 style +="</style>";
129
130 var now;
131
132 if (typeof(arguments[0])=="string"){
133
134 selectDate = arguments[0].split("-");
135
136 var year = selectDate[0];
137
138 var month = parseInt(selectDate[1])-1+"";
139
140 var date = selectDate[2];
141
142 now = new Date(year,month,date);
143
144 }else if (typeof(arguments[0])=="object"){
145
146 now = arguments[0];
147
148 }
149
150
151
152 var lastMonthEndDate = HS_DateAdd("d","-1",now.getFullYear()+"-"+now.getMonth()+"-01").getDate();
153
154 var lastMonthDate = WeekDay(now.getFullYear()+"-"+now.getMonth()+"-01");
155
156 var thisMonthLastDate = HS_DateAdd("d","-1",now.getFullYear()+"-"+(parseInt(now.getMonth())+1).toString()+"-01");
157
158 var thisMonthEndDate = thisMonthLastDate.getDate();
159
160 var thisMonthEndDay = thisMonthLastDate.getDay();
161
162 var todayObj = new Date();
163
164 today = todayObj.getFullYear()+"-"+todayObj.getMonth()+"-"+todayObj.getDate();
165
166 for (i=0; i<lastMonthDate; i++){ // Last Month‘s Date
167
168 lis = "<li><a href=javascript:void(0) onclick=‘_selectThisDay(this)‘ title=‘"+now.getFullYear()+"-"+(parseInt(now.getMonth()))+"-"+lastMonthEndDate+"‘>"+lastMonthEndDate+"</a></li>" + lis;
169
170 lastMonthEndDate--;
171
172 }
173
174 for (i=1; i<=thisMonthEndDate; i++){ // Current Month‘s Date
175
176
177
178 if(today == now.getFullYear()+"-"+now.getMonth()+"-"+i){
179
180 var todayString = now.getFullYear()+"-"+(parseInt(now.getMonth())+1).toString()+"-"+i;
181
182 lis += "<li><a href=javascript:void(0) class=‘today‘ onclick=‘_selectThisDay(this)‘ title=‘"+now.getFullYear()+"-"+(parseInt(now.getMonth())+1)+"-"+i+"‘>"+i+"</a></li>";
183
184
185
186 }else{
187
188 lis += "<li><a href=javascript:void(0) onclick=‘_selectThisDay(this)‘ title=‘"+now.getFullYear()+"-"+(parseInt(now.getMonth())+1)+"-"+i+"‘>"+i+"</a></li>";
189
190
191
192 }
193
194 }
195
196 var j=1;
197
198 for (i=thisMonthEndDay; i<6; i++){ // Next Month‘s Date
199
200 lis += "<li><a href=javascript:void(0) onclick=‘_selectThisDay(this)‘ title=‘"+now.getFullYear()+"-"+(parseInt(now.getMonth())+2)+"-"+j+"‘>"+j+"</a></li>";
201
202 j++;
203
204 }
205
206 lis += style;
207
208 var CalenderTitle = "<a href=‘javascript:void(0)‘ class=‘NextMonth‘ onclick=HS_calender(HS_DateAdd(‘m‘,1,‘"+now.getFullYear()+"-"+now.getMonth()+"-"+now.getDate()+"‘),this) title=‘Next Month‘>?</a>";
209
210 CalenderTitle += "<a href=‘javascript:void(0)‘ class=‘LastMonth‘ onclick=HS_calender(HS_DateAdd(‘m‘,-1,‘"+now.getFullYear()+"-"+now.getMonth()+"-"+now.getDate()+"‘),this) title=‘Previous Month‘>?</a>";
211
212 CalenderTitle += "<span class=‘selectThisYear‘><a href=‘javascript:void(0)‘ onclick=‘CalenderselectYear(this)‘ title=‘Click here to select other year‘ >"+now.getFullYear()+"</a></span>年<span class=‘selectThisMonth‘><a href=‘javascript:void(0)‘ onclick=‘CalenderselectMonth(this)‘ title=‘Click here to select other month‘>"+(parseInt(now.getMonth())+1).toString()+"</a></span>月";
213
214 if (arguments.length>1){
215
216 arguments[1].parentNode.parentNode.getElementsByTagName("ul")[1].innerHTML = lis;
217
218 arguments[1].parentNode.innerHTML = CalenderTitle;
219
220 }else{
221
222 var CalenderBox = style+"<div class=‘calender‘><div class=‘calenderTitle‘>"+CalenderTitle+"</div><div class=‘calenderBody‘><ul class=‘day‘><li>日</li><li>一</li><li>二</li><li>三</li><li>四</li><li>五</li><li>六</li></ul><ul class=‘date‘ id=‘thisMonthDate‘>"+lis+"</ul></div><div class=‘calenderBottom‘><a href=‘javascript:void(0)‘ class=‘closeCalender‘ onclick=‘closeCalender(this)‘>×</a><span><span><a href=javascript:void(0) onclick=‘_selectThisDay(this)‘ title=‘"+todayString+"‘>Today</a></span></span></div></div>";
223
224 return CalenderBox;
225
226 }
227
228 }
229
230 function _selectThisDay(d){
231
232 var boxObj = d.parentNode.parentNode.parentNode.parentNode.parentNode;
233
234
235
236 var title = d.title;
237
238 var res = title.split(‘-‘);
239
240 if(res[1] < 10){
241
242 res[1] = ‘0‘+res[1];
243
244 }
245
246 if(res[2] < 10){
247
248 res[2] = ‘0‘+res[2];
249
250 }
251
252 boxObj.targetObj.value = res[0]+res[1]+res[2];
253
254 boxObj.parentNode.removeChild(boxObj);
255
256 }
257
258 function closeCalender(d){
259
260 var boxObj = d.parentNode.parentNode.parentNode;
261
262 boxObj.parentNode.removeChild(boxObj);
263
264 }
265
266 function CalenderselectYear(obj){
267
268 var opt = "";
269
270 var thisYear = obj.innerHTML;
271
272 for (i=1970; i<=2020; i++){
273
274 if (i==thisYear){
275
276 opt += "<option value="+i+" selected>"+i+"</option>";
277
278 }else{
279
280 opt += "<option value="+i+">"+i+"</option>";
281
282 }
283
284 }
285
286 opt = "<select onblur=‘selectThisYear(this)‘ onchange=‘selectThisYear(this)‘ style=‘font-size:11px‘>"+opt+"</select>";
287
288 obj.parentNode.innerHTML = opt;
289
290 }
291
292 function selectThisYear(obj){
293
294 HS_calender(obj.value+"-"+obj.parentNode.parentNode.getElementsByTagName("span")[1].getElementsByTagName("a")[0].innerHTML+"-1",obj.parentNode);
295
296 }
297
298 function CalenderselectMonth(obj){
299
300 var opt = "";
301
302 var thisMonth = obj.innerHTML;
303
304 for (i=1; i<=12; i++){
305
306 if (i==thisMonth){
307
308 opt += "<option value="+i+" selected>"+i+"</option>";
309
310 }else{
311
312 opt += "<option value="+i+">"+i+"</option>";
313
314 }
315
316 }
317
318   opt = "<select onblur=‘selectThisMonth(this)‘ onchange=‘selectThisMonth(this)‘ style=‘font-size:11px‘>"+opt+"</select>";
319
320   obj.parentNode.innerHTML = opt;
321
322 }
323
324 function selectThisMonth(obj){
325
326   HS_calender(obj.parentNode.parentNode.getElementsByTagName("span")[0].getElementsByTagName("a")[0].innerHTML+"-"+obj.value+"-1",obj.parentNode);
327
328 }
329
330 function HS_setDate(inputObj){
331
332   var calenderObj = document.createElement("span");
333
334   calenderObj.innerHTML = HS_calender(new Date());
335
336   calenderObj.style.position = "absolute";
337
338   calenderObj.style.zIndex = "10009";
339
340   calenderObj.targetObj = inputObj;
341
342   inputObj.parentNode.insertBefore(calenderObj,inputObj.nextSibling);
343
344 }

根据一篇js日历插件改写的,布布扣,bubuko.com

时间: 2024-10-24 12:48:45

根据一篇js日历插件改写的的相关文章

calendar.js一款轻量级的原生js日历插件

使用说明: 需要引入插件calendar.js/calendar.min.js 须要引入calendar.css 样式表,可以自定义自己想要的皮肤 本日历插件支持cmd模块化 如下调用: xvDate({ 'targetId':'date1',//时间写入对象的id 'triggerId':['date1','dateBtn1'],//触发事件的对象id 'alignId':'datesWrap1',//日历对齐对象 'format':'-',//时间格式 默认'YYYY-MM-DD HH:MM

jquery.jCal.js显示日历插件

描述:日历插件jCal用于需要输入日期的表单文本框. 兼容浏览器:IE浏览器/Firefox/Google Chrome 官方链接: http://www.overset.com/2008/05/1 … cker-jquery-plugin/ JS下载: http://www.ijquery.cn/js/jquery.jCal.min.js 预览:  http://www.ijquery.cn/demo/jCal 打包下载: http://www.ijquery.cn/demo/jCal/jCa

被逼着写的jquery工作日管理日历插件

因为工作原因,在我刚进入新公司之后,立马要求让我做一个jquery的插件demo.我的天,我面试的可是.net工程师啊.虽然以前接触过js,jquery,但也只是接触过一丢丢啊,没办法,只好硬着头皮上了.写的不好,功能不完善,毕竟只是个小小的demo,不要喷我. 在恶补了不少js知识之后,由于水平有限(其实是一脸懵逼),就找了网上开源的日历插件学习,再貌似看懂了之后,开始了我的创作之旅(抄袭之路). 先定一个小目标,比如先写一个通用插件写法. 通过看了多篇的博客和视频,终于掌握了jquery插件

javascript日历插件

最近在尝试着写javascript日历插件,所以也到github上看国外人日历源码,或者国内人写的好点的,也在研究点,虽然看到网上有一大把的日历控件,但是没有几个是自己想要的,虽然效果是实现了,但是看他们的源码,头有点大,所以自己也在研究这方面的东西.周末用了2天来研究别人写的代码 自己也试着做做demo,今天正好基本功能完成了,所以趁着这个机会分享下:我们可以先来看看效果:JSFiddler地址如下: demo链接请点击我 基本的配置如下:    targetCls '',    输入框dom

JS日历控件 灵活设置: 精确的时分秒.

在今年7月份时候 写了一篇关于 "JS日历控件" 的文章 , 当时只支持 年月日 的日历控件,现在优化如下: 1. 在原基础上 支持 yyyy-mm-dd 的年月日的控件. 2. 在原基础上增加支持 yyyy-mm-dd HH:MM 年月日时分的控件. 3. 在原基础上增加支持 yyyy-mm-dd HH:MM:SS 年月日时分秒的控件. 4. 增加确定按钮 及 今天 和关闭按钮.当我切换到其他年份的时候,我点击 "今天"按钮 就可以返回当前的年月份. 配置项如下:

Kalendae——一款功能强大的日历插件

url:http://zjingwen.github.io/SetTimeOutGoBlog/kalendae/index.html (如果打开过慢,或者打不开,原因你懂得.) 一.Kalendae--一款功能强大的日历插件,英文版的,我英文太渣,有没有找到,中文文档.只能自己慢慢翻译,鼓捣了. 二.基本信息 Kalendae支持多种日历样式,可双联.单联.多联,支持单选日期,多选日期.联排选择.跨月选择.而且依赖图片极少,对于使用css来重构UI界面,非常有利. 依赖于了kaledae.js.

【UI插件】简单的日历插件(下)—— 学习MVC思想

前言 我们上次写了一个简单的日历插件,但是只是一个半成品,而且做完后发现一些问题,于是我们今天尝试来解决这些问题 PS:距离上次貌似很久了 上次,我们大概遇到哪些问题呢: ① 既然想做一套UI库,那么就应该考虑其它UI库的接入问题 这个意思就是,我们的系统中所有UI插件应该有一些统一行为,我们如果希望统一为所有的插件加一点什么东西,需要有位置可加 这个意味着,可能我们所有的插件需要继承至一个抽象的UI类,并且该类提供了通用的几个事件点 ② 上次做的日历插件虽然说是简单,其耦合还是比较严重的(其实

基于jQuery的日历插件

上个星期看到同事做一个有关日历提醒功能的需求,为了找个插件也是费了不少心思,然后刚好有时间就试着写了一个简单demo 来看下最终效果图吧: 是长得丑了一点,不要吐槽我-.- 首先来说说这个日历主要的制作逻辑吧: ·一个月份最多有31天,需要一个7X6的表格去装载 ·如果知道了某个月份1号是星期几,这个月份有多少天,一个循环就可以显示某个月的日历了吧(眼睛都放光了*.*) ·加上一些控件让用户可以方便操作吧(比如可以输入年份.月份,可以点击选择年份.月份) 新建一个html文件,html结构: <

JavaScript之jQuery-7 jQuery 使用插件(使用插件、日历插件、表单验证插件)

一.jQuery 使用插件 插件的查找与帮助 - jQuery 官方网站的插件库(http://plugins.jquery.com) 提供了大量的插件.并给出去了每个插件的用户评级.版本及bug等 - 库中列出了每个插件的ZIP文件下载.演示.示例代码及教程 使用插件 - step 1:将插件包导入到页面中,并确保它在jQuery源文件之后 <script src="jqeury-1.11.1.js"></script> <script></