var Calendar = Class.create();
Calendar.prototype = {
initialize : function(e, obj) {
this.event = (e) ? e : window.event;
this.obj = obj;
this.today = this.today = new Date();
this.year = this.today.getFullYear();
this.month = this.today.getMonth();
this.date = 1;
this.dayIndex = new Array('일','월','화','수','목','금','토');
this.lastDate = new Array(31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31);
this.calWin = window.open('', 'calendar', 'width=200,height=180,top='+(this.event.clientY+100)+',left='+this.event.clientX);
this.makeCal();
},
makeCal : function(type, addSub) {
this.newDate = new Date(this.year, this.month, this.date);
if(type && addSub) {
if(type == 'year') {
if(addSub == 'add') this.newDate.setFullYear(this.newDate.getFullYear()+1); else this.newDate.setFullYear(this.newDate.getFullYear()-1);
} else if(type == 'month') {
if(addSub == 'add') this.newDate.setMonth(this.newDate.getMonth()+1); else this.newDate.setMonth(this.newDate.getMonth()-1);
}
}
this.year = this.newDate.getFullYear();
this.month = this.newDate.getMonth();
this.day = this.newDate.getDay();
if(((this.year%4 == 0) && (this.year%100 != 0)) || (this.year%400 ==0)) {
this.lastDate[1] = 29;
} else {
this.lastDate[1] = 28;
}
_cal = this;
this.calsrc = "<table border='0' cellpadding='0' cellspacing='1' borderColor='#eeeeee' width='100%'>\n";
this.calsrc += "<tr>\n";
this.calsrc += "<td><span onClick=opener._cal.makeCal('year','sub')><<</span> <span onClick=opener._cal.makeCal('month','sub')><</span></td>\n";
this.calsrc += "<td>"+this.newDate.getFullYear()+"년 "+(this.month+1)+"월</td>\n";
this.calsrc += "<td><span onClick=opener._cal.makeCal('month','add')>></span> <span onClick=opener._cal.makeCal('year','add')>>></span></td>\n";
this.calsrc += "</tr>\n";
this.calsrc += "</table>\n";
this.calsrc += "<table border='0' cellpadding='0' cellspacing='1' borderColor='#eeeeee' width='100%'>\n";
this.calsrc += "<tr>\n";
for(i=0; i<this.dayIndex.length; i++) {
this.calsrc += "<td>"+this.dayIndex[i]+"</td>\n";
}
this.calsrc += "</tr>\n";
for(i=0; i<this.day+this.lastDate[this.newDate.getMonth()];i++) {
if(!(i%7)) {
this.calsrc += "</tr>\n";
this.calsrc += "<tr>\n";
}
if(i >= this.day) {
this.calsrc += "<td><span onClick=opener._cal.setDate('"+((i-this.day)+1)+"')>"+((i-this.day)+1)+"</td>\n";
} else {
this.calsrc += "<td></td>\n";
}
}
this.calsrc += "</tr>\n";
this.calsrc += "</table>\n";
this.calWin.document.open();
this.calWin.document.clear();
this.calWin.document.write(this.calsrc);
this.calWin.document.close();
},
fillZero : function(len, value) {
var value = value.toString();
var addLen = len - value.length;
for(i=0; i<addLen; i++) {
value = "0"+value;
}
return value;
},
setDate : function(day) {
$(this.obj).value = this.year+'-'+this.fillZero(2,this.month+1)+'-'+this.fillZero(2,day);
this.calWin.close();
}
}
<input type="text" name="date" id="date'><input type="button" onClick="new Calendar(event, 'date')" value="달력" />
이렇게 사용하면 됩니다.
급조하느라 부족한부분이 많습니다.
Calendar.prototype = {
initialize : function(e, obj) {
this.event = (e) ? e : window.event;
this.obj = obj;
this.today = this.today = new Date();
this.year = this.today.getFullYear();
this.month = this.today.getMonth();
this.date = 1;
this.dayIndex = new Array('일','월','화','수','목','금','토');
this.lastDate = new Array(31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31);
this.calWin = window.open('', 'calendar', 'width=200,height=180,top='+(this.event.clientY+100)+',left='+this.event.clientX);
this.makeCal();
},
makeCal : function(type, addSub) {
this.newDate = new Date(this.year, this.month, this.date);
if(type && addSub) {
if(type == 'year') {
if(addSub == 'add') this.newDate.setFullYear(this.newDate.getFullYear()+1); else this.newDate.setFullYear(this.newDate.getFullYear()-1);
} else if(type == 'month') {
if(addSub == 'add') this.newDate.setMonth(this.newDate.getMonth()+1); else this.newDate.setMonth(this.newDate.getMonth()-1);
}
}
this.year = this.newDate.getFullYear();
this.month = this.newDate.getMonth();
this.day = this.newDate.getDay();
if(((this.year%4 == 0) && (this.year%100 != 0)) || (this.year%400 ==0)) {
this.lastDate[1] = 29;
} else {
this.lastDate[1] = 28;
}
_cal = this;
this.calsrc = "<table border='0' cellpadding='0' cellspacing='1' borderColor='#eeeeee' width='100%'>\n";
this.calsrc += "<tr>\n";
this.calsrc += "<td><span onClick=opener._cal.makeCal('year','sub')><<</span> <span onClick=opener._cal.makeCal('month','sub')><</span></td>\n";
this.calsrc += "<td>"+this.newDate.getFullYear()+"년 "+(this.month+1)+"월</td>\n";
this.calsrc += "<td><span onClick=opener._cal.makeCal('month','add')>></span> <span onClick=opener._cal.makeCal('year','add')>>></span></td>\n";
this.calsrc += "</tr>\n";
this.calsrc += "</table>\n";
this.calsrc += "<table border='0' cellpadding='0' cellspacing='1' borderColor='#eeeeee' width='100%'>\n";
this.calsrc += "<tr>\n";
for(i=0; i<this.dayIndex.length; i++) {
this.calsrc += "<td>"+this.dayIndex[i]+"</td>\n";
}
this.calsrc += "</tr>\n";
for(i=0; i<this.day+this.lastDate[this.newDate.getMonth()];i++) {
if(!(i%7)) {
this.calsrc += "</tr>\n";
this.calsrc += "<tr>\n";
}
if(i >= this.day) {
this.calsrc += "<td><span onClick=opener._cal.setDate('"+((i-this.day)+1)+"')>"+((i-this.day)+1)+"</td>\n";
} else {
this.calsrc += "<td></td>\n";
}
}
this.calsrc += "</tr>\n";
this.calsrc += "</table>\n";
this.calWin.document.open();
this.calWin.document.clear();
this.calWin.document.write(this.calsrc);
this.calWin.document.close();
},
fillZero : function(len, value) {
var value = value.toString();
var addLen = len - value.length;
for(i=0; i<addLen; i++) {
value = "0"+value;
}
return value;
},
setDate : function(day) {
$(this.obj).value = this.year+'-'+this.fillZero(2,this.month+1)+'-'+this.fillZero(2,day);
this.calWin.close();
}
}
<input type="text" name="date" id="date'><input type="button" onClick="new Calendar(event, 'date')" value="달력" />
이렇게 사용하면 됩니다.
급조하느라 부족한부분이 많습니다.
[이 게시물은 관리자님에 의해 2011-10-31 16:57:14 JavaScript에서 이동 됨]
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 8230 | 9년 전 | 49 | ||
| 8229 | 9년 전 | 51 | ||
| 8228 |
커네드커네드
|
9년 전 | 95 | |
| 8227 | 9년 전 | 108 | ||
| 8226 | 9년 전 | 142 | ||
| 8225 | 9년 전 | 132 | ||
| 8224 | 9년 전 | 130 | ||
| 8223 | 9년 전 | 88 | ||
| 8222 |
|
9년 전 | 161 | |
| 8221 | 9년 전 | 77 | ||
| 8220 | 9년 전 | 74 | ||
| 8219 | 9년 전 | 78 | ||
| 8218 | 9년 전 | 111 | ||
| 8217 |
star3840
|
9년 전 | 95 | |
| 8216 | 9년 전 | 134 | ||
| 8215 | 9년 전 | 84 | ||
| 8214 | 9년 전 | 203 | ||
| 8213 | 9년 전 | 141 | ||
| 8212 | 9년 전 | 55 | ||
| 8211 | 9년 전 | 221 | ||
| 8210 | 9년 전 | 216 | ||
| 8209 | 9년 전 | 317 | ||
| 8208 | 9년 전 | 185 | ||
| 8207 | 9년 전 | 198 | ||
| 8206 |
|
9년 전 | 162 | |
| 8205 | 9년 전 | 146 | ||
| 8204 | 9년 전 | 108 | ||
| 8203 | 9년 전 | 203 | ||
| 8202 | 9년 전 | 125 | ||
| 8201 | 9년 전 | 164 | ||
| 8200 | 9년 전 | 134 | ||
| 8199 | 9년 전 | 182 | ||
| 8198 | 9년 전 | 154 | ||
| 8197 | 9년 전 | 134 | ||
| 8196 | 9년 전 | 513 | ||
| 8195 | 9년 전 | 133 | ||
| 8194 | 9년 전 | 266 | ||
| 8193 | 9년 전 | 134 | ||
| 8192 | 9년 전 | 163 | ||
| 8191 | 9년 전 | 115 | ||
| 8190 | 9년 전 | 109 | ||
| 8189 | 9년 전 | 164 | ||
| 8188 | 9년 전 | 110 | ||
| 8187 | 9년 전 | 119 | ||
| 8186 | 9년 전 | 130 | ||
| 8185 | 9년 전 | 291 | ||
| 8184 | 9년 전 | 84 | ||
| 8183 | 9년 전 | 308 | ||
| 8182 | 9년 전 | 137 | ||
| 8181 | 9년 전 | 113 | ||
| 8180 | 9년 전 | 677 | ||
| 8179 | 9년 전 | 474 | ||
| 8178 | 9년 전 | 276 | ||
| 8177 |
kiplayer
|
9년 전 | 283 | |
| 8176 | 9년 전 | 328 | ||
| 8175 | 9년 전 | 203 | ||
| 8174 | 9년 전 | 210 | ||
| 8173 | 9년 전 | 322 | ||
| 8172 | 9년 전 | 166 | ||
| 8171 | 9년 전 | 159 | ||
| 8170 | 9년 전 | 277 | ||
| 8169 |
커네드커네드
|
9년 전 | 243 | |
| 8168 | 9년 전 | 295 | ||
| 8167 | 9년 전 | 304 | ||
| 8166 | 9년 전 | 216 | ||
| 8165 | 9년 전 | 147 | ||
| 8164 | 9년 전 | 278 | ||
| 8163 | 9년 전 | 264 | ||
| 8162 | 9년 전 | 271 | ||
| 8161 | 9년 전 | 269 | ||
| 8160 |
|
9년 전 | 466 | |
| 8159 | 9년 전 | 383 | ||
| 8158 | 9년 전 | 203 | ||
| 8157 | 9년 전 | 339 | ||
| 8156 | 9년 전 | 255 | ||
| 8155 | 9년 전 | 231 | ||
| 8154 |
00년생용띠
|
9년 전 | 576 | |
| 8153 | 9년 전 | 203 | ||
| 8152 |
|
9년 전 | 384 | |
| 8151 | 9년 전 | 385 | ||
| 8150 | 9년 전 | 474 | ||
| 8149 |
Jangfolk
|
9년 전 | 313 | |
| 8148 | 9년 전 | 148 | ||
| 8147 | 9년 전 | 356 | ||
| 8146 | 9년 전 | 410 | ||
| 8145 | 9년 전 | 341 | ||
| 8144 | 9년 전 | 305 | ||
| 8143 | 9년 전 | 162 | ||
| 8142 | 9년 전 | 407 | ||
| 8141 | 9년 전 | 357 | ||
| 8140 | 9년 전 | 904 | ||
| 8139 | 9년 전 | 228 | ||
| 8138 |
전갈자리남자
|
9년 전 | 372 | |
| 8137 | 9년 전 | 355 | ||
| 8136 | 9년 전 | 716 | ||
| 8135 |
|
9년 전 | 767 | |
| 8134 |
PlayPixel
|
9년 전 | 478 | |
| 8133 |
|
9년 전 | 420 | |
| 8132 | 9년 전 | 430 | ||
| 8131 | 9년 전 | 786 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기