A

간단한 날짜입력용 자바스크립트 달력입니다.

· 17년 전 · 2794
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="달력" />

이렇게 사용하면 됩니다.
급조하느라 부족한부분이 많습니다.
[이 게시물은 관리자님에 의해 2011-10-31 16:57:14 JavaScript에서 이동 됨]
|
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
17년 전 조회 1,624
17년 전 조회 1,455
17년 전 조회 2,524
17년 전 조회 1,493
17년 전 조회 1,084
17년 전 조회 1,218
17년 전 조회 3,094
17년 전 조회 2,159
17년 전 조회 1,966
17년 전 조회 1,210
17년 전 조회 2,445
17년 전 조회 1,166
17년 전 조회 1,125
17년 전 조회 1,366
17년 전 조회 2,731
17년 전 조회 2,388
17년 전 조회 2,473
17년 전 조회 1,175
17년 전 조회 1,290
17년 전 조회 3,238
17년 전 조회 2,825
17년 전 조회 4,092
17년 전 조회 2,253
17년 전 조회 2,348
17년 전 조회 1,397
17년 전 조회 2,516
17년 전 조회 2,203
17년 전 조회 2,962
17년 전 조회 2,472
17년 전 조회 1,633
17년 전 조회 2,425
17년 전 조회 1,585
17년 전 조회 1,173
17년 전 조회 2,233
17년 전 조회 2,878
17년 전 조회 4,055
17년 전 조회 3,143
17년 전 조회 1,410
17년 전 조회 1,706
17년 전 조회 2,240
17년 전 조회 1,545
17년 전 조회 1,718
17년 전 조회 2,711
17년 전 조회 2,135
17년 전 조회 1,789
17년 전 조회 4,193
17년 전 조회 3,040
17년 전 조회 1,433
17년 전 조회 3,565
17년 전 조회 2,795
17년 전 조회 2,075
17년 전 조회 1,291
17년 전 조회 2,324
17년 전 조회 2,064
17년 전 조회 1,977
17년 전 조회 1,920
17년 전 조회 1,171
17년 전 조회 1,875
17년 전 조회 2,929
17년 전 조회 1,430
17년 전 조회 1,671
17년 전 조회 1,352
17년 전 조회 1,599
17년 전 조회 1,572
17년 전 조회 1,445
17년 전 조회 2,558
17년 전 조회 2,322
17년 전 조회 2,103
17년 전 조회 1,412
17년 전 조회 2,425
17년 전 조회 4,247
17년 전 조회 2,736
17년 전 조회 1,657
17년 전 조회 1,851
17년 전 조회 3,228
17년 전 조회 2,230
17년 전 조회 3,824
17년 전 조회 1,673
17년 전 조회 2,269
17년 전 조회 2,098
17년 전 조회 1,613
17년 전 조회 2,128
17년 전 조회 1,925
17년 전 조회 1,959
17년 전 조회 3,073
17년 전 조회 2,147
17년 전 조회 1,436
17년 전 조회 1,458
17년 전 조회 2,124
17년 전 조회 3,199
17년 전 조회 2,137
17년 전 조회 1,528
17년 전 조회 4,235
17년 전 조회 2,024
17년 전 조회 3,456
17년 전 조회 6,030
17년 전 조회 1,483
17년 전 조회 1,653
17년 전 조회 1,234
17년 전 조회 1,345
🐛 버그신고