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 }
时间: 2024-10-24 12:48:45