js代码
- // JavaScript Document
- var browser=navigator.appName;//浏览器名称
- var language = 'en';
- var enablePast = 0;
- var fixedX = -1;
- var fixedY = -1;
- var startAt = 1;
- var showWeekNumber = 0;
- var showToday = 1;
- var imgDir = 'images/';
- var dayName = '日';
- var gotoString = {
- en : '当前月'
- };
- var todayString = {
- en : '今天:'
- };
- var weekString = {
- en : '星期'
- };
- var scrollLeftMessage = {
- en : '上月'
- };
- var scrollRightMessage = {
- en : '下月'
- };
- var selectMonthMessage = {
- en : '选择月份.'
- };
- var selectYearMessage = {
- en : '选择年份.'
- };
- var selectDateMessage = {
- en : 'Go'
- };
- var monthName = {
- en : new Array('1月','2月','3月','4月','5月','6月','7月','8月','9月','10月','11月','12月')
- };
- var monthName2 = {
- en : new Array('1','2','3','4','5','6','7','8','9','10','11','12')
- };
- if (startAt==0) {
- dayName = {
- en : new Array('星期日','星期一','星期二','星期三','星期四','星期五','星期六')
- };
- } else {
- dayName = {
- en : new Array('一','二','三','四','五','六','日')
- };
- }
- var crossobj, crossMonthObj, crossYearObj, monthSelected, yearSelected, dateSelected, omonthSelected, oyearSelected, odateSelected, monthConstructed, yearConstructed, intervalID1, intervalID2, timeoutID1, timeoutID2, ctlToPlaceValue, ctlNow, dateFormat, nStartingYear, selDayAction, isPast;
- var visYear = 0;
- var visMonth = 0;
- var bPageLoaded = false;
- var ie = document.all;
- var dom = document.getElementById;
- var ns4 = document.layers;
- var today = new Date();
- var dateNow = today.getDate();
- var monthNow = today.getMonth();
- //var yearNow = today.getYear();
- if(browser=="Microsoft Internet Explorer"){
- var yearNow = today.getYear();
- }else{
- var yearNow = today.getYear()+1900;
- }
- var timeNow = today.getHours() + ":" + today.getMinutes() +":" + today.getSeconds();
- var imgsrc = new Array('pcaldrop1.gif','pcaldrop2.gif','pcalleft1.gif','pcalleft2.gif','pcalright1.gif','pcalright2.gif');
- var img = new Array();
- var bShow = false;
- function hideElement( elmID, overDiv ) {
- if(ie) {
- for(i = 0; i < document.all.tags( elmID ).length; i++) {
- obj = document.all.tags( elmID )[i];
- if(!obj || !obj.offsetParent) continue;
- // Find the element's offsetTop and offsetLeft relative to the BODY tag.
- objLeft = obj.offsetLeft;
- objTop = obj.offsetTop;
- objParent = obj.offsetParent;
- while(objParent.tagName.toUpperCase() != 'BODY') {
- objLeft += objParent.offsetLeft;
- objTop += objParent.offsetTop;
- objParent = objParent.offsetParent;
- }
- objHeight = obj.offsetHeight;
- objWidth = obj.offsetWidth;
- if((overDiv.offsetLeft + overDiv.offsetWidth) <= objLeft);
- else if((overDiv.offsetTop + overDiv.offsetHeight) <= objTop);
- /* CHANGE by Charlie Roche for nested TDs*/
- else if(overDiv.offsetTop >= (objTop + objHeight + obj.height));
- /* END CHANGE */
- else if(overDiv.offsetLeft >= (objLeft + objWidth));
- else {
- obj.style.visibility = 'hidden';
- }
- }
- }
- }
- function showElement(elmID) {
- if(ie) {
- for(i = 0; i < document.all.tags( elmID ).length; i++) {
- obj = document.all.tags(elmID)[i];
- if(!obj || !obj.offsetParent) continue;
- obj.style.visibility = '';
- }
- }
- }
- function HolidayRec (d, m, y, desc) {
- this.d = d;
- this.m = m;
- this.y = y;
- this.desc = desc;
- }
- var HolidaysCounter = 0;
- var Holidays = new Array();
- function addHoliday (d, m, y, desc) {
- Holidays[HolidaysCounter++] = new HolidayRec (d, m, y, desc);
- }
- if (dom) {
- for (i=0;i<imgsrc.length;i++) {
- img[i] = new Image;
- img[i].src = imgDir + imgsrc[i];
- }
- document.write ('<div οnclick="bShow=true" id="calendar" style="z-index:+999;position:absolute;visibility:hidden;"><table width="'+((showWeekNumber==1)?250:220)+'" style="font-family:ms shell dlg;font-size:12px;border: 1px solid #A0A0A0;" bgcolor="#ffffff"><tr bgcolor="#000066"><td><table width="'+((showWeekNumber==1)?248:218)+'"><tr><td style="padding:2px;font-family:ms shell dlg;font-size:12px;"><font color="#ffffff' + '' /*C9D3E9*/ +'"><b><span id="caption"></span></b></font></td><td align="right"><a href="javascript:hideCalendar()"><img src="'+imgDir+'pcalclose.gif" width="15" height="13" border="0" /></a></td></tr></table></td></tr><tr><td style="padding:5px" bgcolor="#ffffff"><span id="content"></span></td></tr>');
- if (showToday == 1) {
- document.write ('<tr bgcolor="#f0f0f0"><td style="padding:5px" align="center"><span id="lblToday"></span></td></tr>');
- }
- document.write ('</table></div><div id="selectMonth" style="z-index:+999;position:absolute;visibility:hidden;"></div><div id="selectYear" style="z-index:+999;position:absolute;visibility:hidden;"></div>');
- }
- var styleAnchor = 'text-decoration:none;color:black;';
- var styleLightBorder = 'border:1px solid #a0a0a0;';
- function swapImage(srcImg, destImg) {
- if (ie) document.getElementById(srcImg).setAttribute('src',imgDir + destImg);
- }
- function init() {
- if (!ns4)
- {
- if (!ie) yearNow += 1900;
- crossobj=(dom)?document.getElementById('calendar').style : ie? document.all.calendar : document.calendar;
- hideCalendar();
- crossMonthObj = (dom) ? document.getElementById('selectMonth').style : ie ? document.all.selectMonth : document.selectMonth;
- crossYearObj = (dom) ? document.getElementById('selectYear').style : ie ? document.all.selectYear : document.selectYear;
- monthConstructed = false;
- yearConstructed = false;
- if (showToday == 1) {
- document.getElementById('lblToday').innerHTML = '<font color="#000066">' + todayString[language] + ' <a οnmοusemοve="window.status=/''+gotoString[language]+'/'" οnmοuseοut="window.status=/'/'" title="'+gotoString[language]+'" style="'+styleAnchor+'" href="javascript:monthSelected=monthNow;yearSelected=yearNow;constructCalendar();">'+weekString[language]+dateNow+','+yearNow+'年'+monthName[language][monthNow].substring(0,3)+dayName[language][(today.getDay()-startAt==-1)?6:(today.getDay()-startAt)]+', ' + dateNow + '</a></font>';
- }
- sHTML1 = '<span id="spanLeft" style="border:1px solid #36f;cursor:pointer" οnclick="decMonth()" οnmοusedοwn="clearTimeout(timeoutID1);timeoutID1=setTimeout(/'StartDecMonth()/',500)" οnmοuseup="clearTimeout(timeoutID1);clearInterval(intervalID1)"> <img id="changeLeft" src="'+imgDir+'pcalleft1.gif" width="10" height="11" border="0"> </span> ';
- sHTML1 += '<span id="spanRight" style="border:1px solid #36f;cursor:pointer" οnclick="incMonth()" οnmοusedοwn="clearTimeout(timeoutID1);timeoutID1=setTimeout(/'StartIncMonth()/',500)" οnmοuseup="clearTimeout(timeoutID1);clearInterval(intervalID1)"> <img id="changeRight" src="'+imgDir+'pcalright1.gif" width="10" height="11" border="0"> </span> ';
- sHTML1 += '<span id="spanMonth" style="border:1px solid #36f;cursor:pointer" οnclick="popUpMonth()"></span> ';
- sHTML1 += '<span id="spanYear" style="border:1px solid #36f;cursor:pointer" οnclick="popUpYear()"></span> ';
- document.getElementById('caption').innerHTML = sHTML1;
- bPageLoaded=true;
- }
- }
- function hideCalendar() {
- crossobj.visibility = 'hidden';
- if (crossMonthObj != null) crossMonthObj.visibility = 'hidden';
- if (crossYearObj != null) crossYearObj.visibility = 'hidden';
- showElement('SELECT');
- showElement('APPLET');
- }
- function padZero(num) {
- return (num < 10) ? '0' + num : num;
- }
- function constructDate(d,m,y, t) {
- sTmp = dateFormat;
- sTmp = sTmp.replace ('dd','<e>');
- sTmp = sTmp.replace ('d','<d>');
- sTmp = sTmp.replace ('<e>',padZero(d));
- sTmp = sTmp.replace ('<d>',d);
- sTmp = sTmp.replace ('mmmm','<p>');
- sTmp = sTmp.replace ('mmm','<o>');
- sTmp = sTmp.replace ('mm','<n>');
- sTmp = sTmp.replace ('m','<m>');
- sTmp = sTmp.replace ('<m>',m+1);
- sTmp = sTmp.replace ('<n>',padZero(m+1));
- sTmp = sTmp.replace ('<o>',monthName[language][m]);
- sTmp = sTmp.replace ('<p>',monthName2[language][m]);
- sTmp = sTmp.replace ('yyyy',y);
- sTmp = sTmp.replace ('yy',padZero(y%100));
- return sTmp.replace ('tt',t);
- }
- function closeCalendar() {
- var timed = new Date();
- var tt = timed.getHours() + ":" + timed.getMinutes() + ":" +timed.getSeconds() + "";
- //alert(typeof tt + "is type of dataeSelected");
- //alert(tt +"is the return value");
- hideCalendar();
- ctlToPlaceValue.value = constructDate(dateSelected,monthSelected,yearSelected, tt );
- }
- /*** Month Pulldown ***/
- function StartDecMonth() {
- intervalID1 = setInterval("decMonth()",80);
- }
- function StartIncMonth() {
- intervalID1 = setInterval("incMonth()",80);
- }
- function incMonth () {
- monthSelected++;
- if (monthSelected > 11) {
- monthSelected = 0;
- yearSelected++;
- }
- constructCalendar();
- }
- function decMonth () {
- monthSelected--;
- if (monthSelected < 0) {
- monthSelected = 11;
- yearSelected--;
- }
- constructCalendar();
- }
- function constructMonth() {
- popDownYear()
- if (!monthConstructed) {
- sHTML = "";
- for (i=0; i<12; i++) {
- sName = monthName[language][i];
- if (i == monthSelected){
- sName = '<b>' + sName + '</b>';
- }
- sHTML += '<tr><td id="m' + i + '" style="cursor:pointer" οnclick="monthConstructed=false;monthSelected=' + i + ';constructCalendar();popDownMonth();event.cancelBubble=true"><font color="#000066"> ' + sName + ' </font></td></tr>';
- }
- document.getElementById('selectMonth').innerHTML = '<table width="70" style="font-family:ms shell dlg;font-size:12px;border:1px solid #a0a0a0;" bgcolor="#f0f0f0" cellspacing="0" >' + sHTML + '</table>';
- monthConstructed = true;
- }
- }
- function popUpMonth() {
- if (visMonth == 1) {
- popDownMonth();
- visMonth--;
- } else {
- constructMonth();
- crossMonthObj.visibility = (dom||ie) ? 'visible' : 'show';
- crossMonthObj.left = parseInt(crossobj.left) + 50;
- crossMonthObj.top = parseInt(crossobj.top) + 26;
- hideElement('SELECT', document.getElementById('selectMonth'));
- hideElement('APPLET', document.getElementById('selectMonth'));
- visMonth++;
- }
- }
- function popDownMonth() {
- crossMonthObj.visibility = 'hidden';
- visMonth = 0;
- }
- /*** Year Pulldown ***/
- function incYear() {
- for (i=0; i<7; i++) {
- newYear = (i + nStartingYear) + 1;
- if (newYear == yearSelected)
- txtYear = '<span style="color:#006;font-weight:bold;"> ' + newYear + ' </span>';
- else
- txtYear = '<span style="color:#006;"> ' + newYear + ' </span>';
- document.getElementById('y'+i).innerHTML = txtYear;
- }
- nStartingYear++;
- bShow=true;
- }
- function decYear() {
- for (i=0; i<7; i++) {
- newYear = (i + nStartingYear) - 1;
- if (newYear == yearSelected)
- txtYear = '<span style="color:#006;font-weight:bold"> ' + newYear + ' </span>';
- else
- txtYear = '<span style="color:#006;"> ' + newYear + ' </span>';
- document.getElementById('y'+i).innerHTML = txtYear;
- }
- nStartingYear--;
- bShow=true;
- }
- function selectYear(nYear) {
- yearSelected = parseInt(nYear + nStartingYear);
- yearConstructed = false;
- constructCalendar();
- popDownYear();
- }
- function constructYear() {
- popDownMonth();
- sHTML = '';
- if (!yearConstructed) {
- sHTML = '<tr><td align="center" style="cursor:pointer" οnmοusedοwn="clearInterval(intervalID1);intervalID1=setInterval(/'decYear()/',30)" οnmοuseup="clearInterval(intervalID1)"><font color="#000066">-</font></td></tr>';
- j = 0;
- nStartingYear = yearSelected - 3;
- for ( i = (yearSelected-3); i <= (yearSelected+3); i++ ) {
- sName = i;
- if (i == yearSelected) sName = '<b>' + sName + '</b>';
- sHTML += '<tr><td id="y' + j + '" style="cursor:pointer" οnclick="selectYear('+j+');event.cancelBubble=true"><font color="#000066"> ' + sName + ' </font></td></tr>';
- j++;
- }
- sHTML += '<tr><td align="center" style="cursor:pointer" οnmοusedοwn="clearInterval(intervalID2);intervalID2=setInterval(/'incYear()/',30)" οnmοuseup="clearInterval(intervalID2)"><font color="#000066">+</font></td></tr>';
- document.getElementById('selectYear').innerHTML = '<table width="44" cellspacing="0" bgcolor="#f0f0f0" style="font-family:ms shell dlg;font-size:12px;border:1px solid #a0a0a0;" >' + sHTML + '</table>';
- yearConstructed = true;
- }
- }
- function popDownYear() {
- clearInterval(intervalID1);
- clearTimeout(timeoutID1);
- clearInterval(intervalID2);
- clearTimeout(timeoutID2);
- crossYearObj.visibility= 'hidden';
- visYear = 0;
- }
- function popUpYear() {
- var leftOffset
- if (visYear==1) {
- popDownYear();
- visYear--;
- } else {
- constructYear();
- crossYearObj.visibility = (dom||ie) ? 'visible' : 'show';
- leftOffset = parseInt(crossobj.left) + document.getElementById('spanYear').offsetLeft;
- if (ie) leftOffset += 6;
- crossYearObj.left = leftOffset;
- crossYearObj.top = parseInt(crossobj.top) + 26;
- visYear++;
- }
- }
- /*** calendar ***/
- function WeekNbr(n) {
- // Algorithm used:
- // From Klaus Tondering's Calendar document (The Authority/Guru)
- // http://www.tondering.dk/claus/calendar.html
- // a = (14-month) / 12
- // y = year + 4800 - a
- // m = month + 12a - 3
- // J = day + (153m + 2) / 5 + 365y + y / 4 - y / 100 + y / 400 - 32045
- // d4 = (J + 31741 - (J mod 7)) mod 146097 mod 36524 mod 1461
- // L = d4 / 1460
- // d1 = ((d4 - L) mod 365) + L
- // WeekNumber = d1 / 7 + 1
- year = n.getFullYear();
- month = n.getMonth() + 1;
- if (startAt == 0) {
- day = n.getDate() + 1;
- } else {
- day = n.getDate();
- }
- a = Math.floor((14-month) / 12);
- y = year + 4800 - a;
- m = month + 12 * a - 3;
- b = Math.floor(y/4) - Math.floor(y/100) + Math.floor(y/400);
- J = day + Math.floor((153 * m + 2) / 5) + 365 * y + b - 32045;
- d4 = (((J + 31741 - (J % 7)) % 146097) % 36524) % 1461;
- L = Math.floor(d4 / 1460);
- d1 = ((d4 - L) % 365) + L;
- week = Math.floor(d1/7) + 1;
- return week;
- }
- function constructCalendar () {
- var aNumDays = Array (31,0,31,30,31,30,31,31,30,31,30,31);
- var dateMessage;
- var startDate = new Date (yearSelected,monthSelected,1);
- var endDate;
- if (monthSelected==1) {
- endDate = new Date (yearSelected,monthSelected+1,1);
- endDate = new Date (endDate - (24*60*60*1000));
- numDaysInMonth = endDate.getDate();
- } else {
- numDaysInMonth = aNumDays[monthSelected];
- }
- datePointer = 0;
- dayPointer = startDate.getDay() - startAt;
- if (dayPointer<0) dayPointer = 6;
- sHTML = '<table border="0" style="font-family:verdana;font-size:12px;"><tr>';
- if (showWeekNumber == 1) {
- sHTML += '<td width="27"><b>' + weekString[language] + '</b></td><td width="1" rowspan="7" bgcolor="#d0d0d0" style="padding:0px"><img src="'+imgDir+'divider.gif" width="1"></td>';
- }
- for (i = 0; i<7; i++) {
- sHTML += '<td width="27" align="right"><b><font color="#000066">' + dayName[language][i] + '</font></b></td>';
- }
- sHTML += '</tr><tr>';
- if (showWeekNumber == 1) {
- sHTML += '<td align="right">' + WeekNbr(startDate) + ' </td>';
- }
- for ( var i=1; i<=dayPointer;i++ ) {
- sHTML += '<td> </td>';
- }
- for ( datePointer=1; datePointer <= numDaysInMonth; datePointer++ ) {
- dayPointer++;
- sHTML += '<td align="right">';
- sStyle=styleAnchor;
- if ((datePointer == odateSelected) && (monthSelected == omonthSelected) && (yearSelected == oyearSelected))
- { sStyle+=styleLightBorder }
- sHint = '';
- for (k = 0;k < HolidaysCounter; k++) {
- if ((parseInt(Holidays[k].d) == datePointer)&&(parseInt(Holidays[k].m) == (monthSelected+1))) {
- if ((parseInt(Holidays[k].y)==0)||((parseInt(Holidays[k].y)==yearSelected)&&(parseInt(Holidays[k].y)!=0))) {
- sStyle+= 'background-color:#fdd;';
- sHint += sHint=="" ? Holidays[k].desc : "/n"+Holidays[k].desc;
- }
- }
- }
- sHint = sHint.replace('//"/g', '"');
- dateMessage = 'οnmοusemοve="window.status=/''+selectDateMessage[language].replace('[date]',constructDate(datePointer,monthSelected,yearSelected, timeNow))+'/'" οnmοuseοut="window.status=/'/'" ';
- if (enablePast == 0 && ((yearSelected < yearNow) || (monthSelected < monthNow) && (yearSelected == yearNow) || (datePointer < dateNow) && (monthSelected == monthNow) && (yearSelected == yearNow))) {
- //selDayAction = '';
- selDayAction = 'href="javascript:dateSelected=' + datePointer + ';closeCalendar();"';
- isPast = 1;
- } else {
- selDayAction = 'href="javascript:dateSelected=' + datePointer + ';closeCalendar();"';
- isPast = 0;
- }
- if ((datePointer == dateNow) && (monthSelected == monthNow) && (yearSelected == yearNow)) { / today
- sHTML += "<b><a "+dateMessage+" title=/"" + sHint + "/" style='"+sStyle+"' "+selDayAction+"><font color=#ff0000> " + datePointer + "</font> </a></b>";
- } else if (dayPointer % 7 == (startAt * -1)+1) { / SI ES DOMINGO
- if (isPast==1)
- sHTML += "<a "+dateMessage+" title=/"" + sHint + "/" style='"+sStyle+"' "+selDayAction+"> <font color=#909090>" + datePointer + "</font> </a>";
- else
- sHTML += "<a "+dateMessage+" title=/"" + sHint + "/" style='"+sStyle+"' "+selDayAction+"> <font color=#54A6E2>" + datePointer + "</font> </a>";
- } else if ((dayPointer % 7 == (startAt * -1)+7 && startAt==1) || (dayPointer % 7 == startAt && startAt==0)) { / SI ES SABADO
- if (isPast==1)
- sHTML += "<a "+dateMessage+" title=/"" + sHint + "/" style='"+sStyle+"' "+selDayAction+"> <font color=#909090>" + datePointer + "</font> </a>";
- else
- sHTML += "<a "+dateMessage+" title=/"" + sHint + "/" style='"+sStyle+"' "+selDayAction+"> <font color=#54A6E2>" + datePointer + "</font> </a>";
- } else { / CUALQUIER OTRO DIA
- if (isPast==1)
- sHTML += "<a "+dateMessage+" title=/"" + sHint + "/" style='"+sStyle+"' "+selDayAction+"> <font color=#909090>" + datePointer + "</font> </a>";
- else
- sHTML += "<a "+dateMessage+" title=/"" + sHint + "/" style='"+sStyle+"' "+selDayAction+"> <font color=#000066>" + datePointer + "</font> </a>";
- }
- sHTML += '';
- if ((dayPointer+startAt) % 7 == startAt) {
- sHTML += '</tr><tr>';
- if ((showWeekNumber == 1) && (datePointer < numDaysInMonth)) {
- sHTML += '<td align="right">' + (WeekNbr(new Date(yearSelected,monthSelected,datePointer+1))) + ' </td>';
- }
- }
- }
- document.getElementById('content').innerHTML = sHTML
- document.getElementById('spanMonth').innerHTML = ' ' + monthName[language][monthSelected] + ' <img id="changeMonth" src="'+imgDir+'pcaldrop1.gif" width="12" height="10" border="0">'
- document.getElementById('spanYear').innerHTML = ' ' + yearSelected + ' <img id="changeYear" src="'+imgDir+'pcaldrop1.gif" width="12" height="10" border="0">';
- }
- function showCalendar(ctl, ctl2, format, lang, past, fx, fy) {
- if (lang != null && lang != '') language = lang;
- if (past != null) enablePast = past;
- else enablePast = 0;
- if (fx != null) fixedX = fx;
- else fixedX = -1;
- if (fy != null) fixedY = fy;
- else fixedY = -1;
- if (showToday == 1) {
- document.getElementById('lblToday').innerHTML = '<font color="#000066">' + todayString[language] + ' <a οnmοusemοve="window.status=/''+gotoString[language]+'/'" οnmοuseοut="window.status=/'/'" title="'+gotoString[language]+'" style="'+styleAnchor+'" href="javascript:monthSelected=monthNow;yearSelected=yearNow;constructCalendar();">'+weekString[language]+dayName[language][(today.getDay()-startAt==-1)?6:(today.getDay()-startAt)]+','+yearNow+'年'+ monthName[language][monthNow].substring(0,3)+dateNow+'日</a></font>';
- }
- popUpCalendar(ctl, ctl2, format);
- }
- function popUpCalendar(ctl, ctl2, format) {
- var leftpos = 0;
- var toppos = 0;
- if (bPageLoaded) {
- if (crossobj.visibility == 'hidden') {
- ctlToPlaceValue = ctl2;
- dateFormat = format;
- formatChar = ' ';
- aFormat = dateFormat.split(formatChar);
- if (aFormat.length < 3) {
- formatChar = '/';
- aFormat = dateFormat.split(formatChar);
- if (aFormat.length < 3) {
- formatChar = '.';
- aFormat = dateFormat.split(formatChar);
- if (aFormat.length < 3) {
- formatChar = '-';
- aFormat = dateFormat.split(formatChar);
- if (aFormat.length < 3) {
- formatChar = ''; // invalid date format
- }
- }
- }
- }
- tokensChanged = 0;
- if (formatChar != "") {
- aData = ctl2.value.split(formatChar); // use user's date
- for (i=0; i<3; i++) {
- if ((aFormat[i] == "d") || (aFormat[i] == "dd")) {
- dateSelected = parseInt(aData[i], 10);
- tokensChanged++;
- } else if ((aFormat[i] == "m") || (aFormat[i] == "mm")) {
- monthSelected = parseInt(aData[i], 10) - 1;
- tokensChanged++;
- } else if (aFormat[i] == "yyyy") {
- yearSelected = parseInt(aData[i], 10);
- tokensChanged++;
- } else if (aFormat[i] == "mmm") {
- for (j=0; j<12; j++) {
- if (aData[i] == monthName[language][j]) {
- monthSelected=j;
- tokensChanged++;
- }
- }
- } else if (aFormat[i] == "mmmm") {
- for (j=0; j<12; j++) {
- if (aData[i] == monthName2[language][j]) {
- monthSelected = j;
- tokensChanged++;
- }
- }
- }
- }
- }
- if ((tokensChanged != 3) || isNaN(dateSelected) || isNaN(monthSelected) || isNaN(yearSelected)) {
- dateSelected = dateNow;
- monthSelected = monthNow;
- yearSelected = yearNow;
- }
- odateSelected = dateSelected;
- omonthSelected = monthSelected;
- oyearSelected = yearSelected;
- aTag = ctl;
- do {
- aTag = aTag.offsetParent;
- leftpos += aTag.offsetLeft;
- toppos += aTag.offsetTop;
- } while (aTag.tagName != 'BODY');
- crossobj.left = (fixedX == -1) ? ctl.offsetLeft + leftpos : fixedX;
- crossobj.top = (fixedY == -1) ? ctl.offsetTop + toppos + ctl.offsetHeight + 2 : fixedY;
- constructCalendar (1, monthSelected, yearSelected);
- crossobj.visibility = (dom||ie) ? "visible" : "show";
- hideElement('SELECT', document.getElementById('calendar'));
- hideElement('APPLET', document.getElementById('calendar'));
- bShow = true;
- } else {
- hideCalendar();
- if (ctlNow!=ctl) popUpCalendar(ctl, ctl2, format);
- }
- ctlNow = ctl;
- }
- }
- document.onkeypress = function hidecal1 () {
- if (event.keyCode == 27) hideCalendar();
- }
- document.onclick = function hidecal2 () {
- if (!bShow) hideCalendar();
- bShow = false;
- }
- /*
- if(ie) {
- init();
- } else {
- window.onload = init;
- }
- */
- if (document.all){
- window.attachEvent('onload',init)
- }
- else{
- window.addEventListener('load',init,false);
- }
调用
<input type="text" value="" id="Field2" name="Field2" size="16" readonly="readonly" onFocus='showCalendar(this, document.getElementById("Field2"), "yyyy-mmmm-dd",null,0,-1,-1)' />
<a href="javascript:;" οnclick='showCalendar(this, document.getElementById("Field2"), "yyyy-mmmm-dd",null,0,-1,-1)'>日历></a>