`

js 中的日历

阅读更多
<!--
<!--
/**
*
* JSCalendar
*
* Author           :H.Z. Shang (Jack)
* Email            :shhongzhang@cntomorrow.com
* Site             :http://www.cntomorrow.com:3310
* Version          :1.0.1
* Finished Date    :2003-3-2
* Beijing Huasun Mingtian Tech. Co., Ltd.
* No CopyRight,Can be modified by you if you want improve it's function!!!!
* LET'S MAKE IT BETTER TOGETHER!
* HISTORY:
*  1. [2003-3-4 by Jack] 采用IFRAME修正了会被页面SELECT对象挡住的BUG!
*  2. [2003-3-4 by Jack] 增加了清空控件值的功能
*  3. [2003-3-5 by Jack] 修正了当用户翻年、翻月时原输入框值被覆盖的情况
*  4. [2003-3-5 by Jack] 通过使用DXImageTransform.Microsoft.Shadow来实现IFRAME的阴影效果
*                        该滤镜只能在IE5.5下使用可加快程序运行速度,在IE5.0中还是使用原来的产生阴影的方法
*  5. [2003-3-6 by Jack] 增加了另外一种生成该控件的方法:<script>createDateBox("Name", "2003-3-6")</script>
*                        其中第二个参数为可选参数
*/

var _cldTabIFrame = null;
var _cldTabIFrame2 = null;

var _cldTabFrm = null;
var _cldMonthMenuFrm = null;
var _curCldTabRltvObj = null;
var _bCanHide = true;
var _bHaveUpdated = false;
var _bHaveShown = false;

var _bHaveSelectNewValue = false;

var _dCurYear = null;
var _dCurMonth = null;
var _dCurDate = null;

var _curCldTabRltvObjValue = "";

/**
  * 在该日历控件中,我采用了给空间周围加上阴影层来增强控件的视觉感。
  * _nShadowLength 变量设定了阴影层的长度,默认值为 4;
  * 使用阴影层将相应的滞缓程序的运行速度,如果你想得到较快的运行速度,请将该值设为 0
  */
var _nShadowLength = 0;

/**
  * _sNeededFilePath 变量设定了JSCalendar控件所需的所有文件的位置
  * 当你将你的应用部署到应用服务器上后,你需要给改变量设定相应的值。
  * 例如:
  * _sNeededFilePath = "/MyWebAPP/comm/js/JSCalendar/";
  *
  * 该变量的值必须正确设置,否则程序在运行中可能出现错误!
  */

var _sNeededImagesFilePath = "../images/";
var _sNeededCSSFilePath = "../style/";


var _sBrowserVersion = navigator.appVersion.substring(navigator.appVersion.indexOf("MSIE") + 5,navigator.appVersion.indexOf("Windows") - 2);
var _bBrowserVer55 = _sBrowserVersion >= 5.5 ? true : false;

/**
  * 定义所需图片
  *
  */
var _imgReset1 = new Image();
_imgReset1.src = _sNeededImagesFilePath + "reset1.gif";
var _imgReset2 = new Image();
_imgReset2.src = _sNeededImagesFilePath + "reset2.gif";
var _imgBtnYear = new Image();
_imgBtnYear.src = _sNeededImagesFilePath + "btnYears.gif";
var _imgBgToday1 = new Image();
_imgBgToday1.src = _sNeededImagesFilePath + "bgToday1.gif";

var _monthDays = new Array(12);
    _monthDays[ 0] = 31;
    _monthDays[ 1] = 28;
    _monthDays[ 2] = 31;
    _monthDays[ 3] = 30;
    _monthDays[ 4] = 31;
    _monthDays[ 5] = 30;
    _monthDays[ 6] = 31;
    _monthDays[ 7] = 31;
    _monthDays[ 8] = 30;
    _monthDays[ 9] = 31;
    _monthDays[10] = 30;
    _monthDays[11] = 31;

var _weeks = new Array(7);   
_weeks[0] = "日";
_weeks[1] = "一";
_weeks[2] = "二";
_weeks[3] = "三";
_weeks[4] = "四";
_weeks[5] = "五";
_weeks[6] = "六";
var _months = new Array(12);
_months[ 0] = "一月";
_months[ 1] = "二月";
_months[ 2] = "三月";
_months[ 3] = "四月";
_months[ 4] = "五月";
_months[ 5] = "六月";
_months[ 6] = "七月";
_months[ 7] = "八月";
_months[ 8] = "九月";
_months[ 9] = "十";
_months[10] = "十一月";
_months[11] = "十二月";

var _dftD = new Date();
document.write("<IFRAME id=frm name=frm style='display:none'></IFRAME>");

function JSCalendar(rltvO, year, month, date){

if(_bHaveUpdated && rltvO == _curCldTabRltvObj) return;
if(rltvO.tagName != "INPUT"){alert("JSCalendar 1.0 alerts you:\n\n INPUT element(object) must be required!");return};

hideCldTabFrm();

//rltvO.readOnly = true;
rltvO.style.cursor = "default";
rltvO.style.textAlign = "center";
_curCldTabRltvObjValue = rltvO.value;
_bHaveSelectNewValue = false;
//------------------------------------------------------------------------------
this.createCldTabFrm = createCldTabFrm;
this.fillCldTabFrm = fillCldTabFrm;
this.placeCldTabFrm = placeCldTabFrm;
//------------------------------------------------------------------------------

this._rltvO = (rltvO == null ? document.body : rltvO);
var _oldDate = rltvO.value;
var _oldDateType = "From Input!";
try{
if(_oldDate == "") throw "";
var d = _oldDate.split("-");
var _tmpDate = getValidateDate(_oldDate);
this._year  = _tmpDate.getFullYear();
this._month = _tmpDate.getMonth();
this._date  = _tmpDate.getDate();
}catch(e){
_debug("Error was be catched:" + e.description);
_oldDateType = "From default or current date!";
this._year = (year == null ? _dftD.getFullYear() : year);
this._month = (month == null ? _dftD.getMonth() : month - 1);;
this._date = (date == null ? _dftD.getDate() : date);
}
//alert(this._year + "-" + (this._month + 1) + "-" + this._date );
_dCurYear = this._year;
_dCurMonth = this._month;
_dCurDate = this._date;

if(_cldTabIFrame == null)
this.createCldTabFrm();

//alert(_cldTabIFrame2)
_cldTabIFrame2.style.display = "inline";

_debug(_oldDateType + "[]" + this._year + "-" + (this._month + 1) + "-" + this._date);
this.fillCldTabFrm(this._year, this._month, this._date);
if(!_bHaveShown || rltvO != _curCldTabRltvObj) this.placeCldTabFrm();

//_cldTabIFrame2.style.display = "inline";

if(!_bBrowserVer55){
removeShadowDiv();
MakeDivShadowEffect(_cldTabFrm, '#aaaaaa', _nShadowLength);
}
_curCldTabRltvObj = this._rltvO;

_bHaveUpdated = true;
_bHaveShown = true;
}
function createCldTabFrm(){
var _sz = "<HTML>"
+ "<HEAD><link href='" +_sNeededCSSFilePath + "JSCalendar.css' rel=stylesheet type='text/css'></HEAD>"
+ "<BODY onselectstart='return false;' leftmargin=0 topmargin=0 rightmargin=0 bottommargin=0 style='cursor:default;background-color:transparent;border:0px solid black;scroll:no'>"
+ "</BODY></HTML>";
_cldTabIFrame = frm;//document.all("frm");//document.createElement("IFRAME");
_cldTabIFrame2 = document.all("frm");
_cldTabIFrame2.style.position = "absolute";

//_cldTabIFrame2.document.body.scroll = "no";
//_cldTabIFrame2.style.pixelWidth = /*_innerTabFrmRect.right - _innerTabFrmRect.left*/  //375 + _nShadowLength;
//_cldTabIFrame2.style.pixelHeight = /*_innerTabFrmRect.bottom - _innerTabFrmRect.top*/ 165 + _nShadowLength;
//_cldTabIFrame2.allowTransparency = true;
if(_bBrowserVer55)
_cldTabIFrame2.style.filter = "progid:DXImageTransform.Microsoft.Shadow(direction=135,color=#aaaaaa,strength=" + _nShadowLength + ")";

_cldTabIFrame.document.open("text/html","replace");
_cldTabIFrame.document.write(_sz);
_cldTabIFrame.document.close();
_cldTabFrm = _cldTabIFrame.document.createElement("TABLE");
_cldTabFrm.id = "JACKSHANGJIELOVEFEIFEI"
_cldTabFrm.style.position = "absolute";
_cldTabFrm.className = "calendar";
_cldTabFrm.border = 0;
_cldTabFrm.height = 165;
_cldTabFrm.style.pixelWidth = 220;
_cldTabFrm.cellSpacing = 1;
_cldTabFrm.cellPadding = 1;
_cldTabFrm.bgColor = "ffffff";
_cldTabFrm.attachEvent("onmouseover", whenMouseOverCldTabFrm);
_cldTabFrm.attachEvent("onmouseout", whenMouseOutCldTabFrm);
// Create Calendar Control header
var _TR = _cldTabFrm.insertRow();
var _TD = _TR.insertCell();
_TD.colSpan = 7;
_TD.align = "center";
_TD.innerHTML = "&nbsp;";//"<b>JS Calendar 1.0 by Jack</b>";
// Create main block
for(var i = 0; i < 7; i++){
_TR = _cldTabFrm.insertRow();
for(var j = 0; j < 7; j++){
_TD = _TR.insertCell();
_TD.style.cursor = "default";
_TD.align = "center";
_TD.width = 50;
//_TD.style.border = "1px solid black";
_TD.innerHTML = "*";
if(i != 0){
_TD.style.cursor = "hand";
_TD.attachEvent("onmouseover", whenMouseOverDateItem);
_TD.attachEvent("onmouseout", whenMouseOutDateItem);
_TD.attachEvent("onclick", whenClickDateItem);
}
if(i == 0) _TD.innerHTML = "<b>" + _weeks[j] + "</b>";
if(i == 0 && (j == 0 || j == 6)) _TD.className = "tdHoliday";
}
}
// Create footer
_TR = _cldTabFrm.insertRow(2);
_TD = _TR.insertCell();
_TD.colSpan = 7;
_TD.height = 1;
_TD.bgColor = "black";
_TR = _cldTabFrm.insertRow();
_TD = _TR.insertCell();
_TD.colSpan = 7;
_TD.innerHTML = "<table cellspacing=0 cellpadding=0 class=calendar style='border:0px solid;width:100%'>"
+ "<tr><td title=   '选择今天'style='cursor:hand'onclick=\"parent._bHaveSelectNewValue=true;parent.setTargetFormaValue(" + _dftD.getFullYear() + "," + (_dftD.getMonth() + 1) + "," + _dftD.getDate() + ");parent.hideCldTabFrm();return;parent.fillCldTabFrm(" + _dftD.getFullYear() + "," + _dftD.getMonth() + "," + _dftD.getDate() + ");\">"
+ "<b>&nbsp;<img src='" + _imgBgToday1.src + "' width=30px>今天: " + _dftD.getFullYear() + "-" + (_dftD.getMonth() + 1) + "-" + _dftD.getDate()
+ "</td>"
+ "<td width=30px>"
+ "<img style='cursor:hand' onclick=parent.resetTargetValue() title='Reset the target value.' src='" + _imgReset1.src + "' onmouseover=this.src='" + _imgReset2.src + "' onmouseout=this.src='" + _imgReset1.src + "'></td>"
+ "<td align=right class=smallFont></td></tr></table>";

_cldTabIFrame.document.body.insertBefore(_cldTabFrm);
}

function fillCldTabFrm(year, month, date){
//return;
var dCurDate = 0;
var dNextMonthDate = 1;
var iDateStartRow = 3;
//var _d = new Date(this._year, this._month, 1);
var _d = new Date(year, month, 1);
//alert(year + "-" + month + "-" + date);
var _day = _d.getDay();
var _td = null;

_dCurYear = year;
_dCurMonth = month;
_dCurDate = date;

if (((_dCurYear % 4 == 0) && !(_dCurYear % 100 == 0))
||(_dCurYear % 400 == 0)) _monthDays[1] = 29;
else _monthDays[1] = 28;

_cldTabFrm.rows(0).cells(0).innerHTML
= "<table bgcolor=420042 class=calendar style=\"color:white;font-weight:bolder;border:0px solid;width:100%;height:20px;\" cellspacing=0 cellpadding=0>"
+ "<tr><td>"
+ "&nbsp;<a style='cursor:hand' title='Last Month' onclick=\"parent.switchLastMonth()\"><<</a>"
+ "</td>"
+ "<td align=center vAlign=middle>"
+ "<map name=mapForBtnYears><area title='Next Year' onclick=parent.switchLastYear() shape=rect coords=0,0,10,5><area title='Last Year' onclick=parent.switchNextYear() shape=rect coords=0,5,10,15></map>"
+ "" + _months[_dCurMonth] + " , " + _dCurYear
+ "&nbsp;<img border=0 align=absMiddle src='" + _imgBtnYear.src + "' style='height:12px;width:10px' usemap=#mapForBtnYears>&nbsp;"
+ "</td>"
+ "<td align=right>"
+ "<a style='cursor:hand' title='Next Month' onclick=\"parent.switchNextMonth()\">>></a>&nbsp"
+ "</td></tr></table>"

_day = (_day == 0 ? 7 : _day);

for(var i = _day - 1, dlt = 0; i >= 0; i--){
_td = _cldTabFrm.rows(iDateStartRow).cells(i);
//_td.disabled = true;
_td.className = "lastMonth";
_td.title = "";
_td.name = "LASTMONTH";
_td.style.backgroundColor = "transparent";
_td.style.border = "0px solid";
var _nextMonth = _dCurMonth - 1;
if(_nextMonth < 0) _nextMonth = 11;
_td.innerText = (_monthDays[_nextMonth] - (dlt++));
}
//alert(_cldTabFrm.rows.length);
i = _day;
for(var d = 1, iRow = iDateStartRow; d <= _monthDays[_dCurMonth] || iRow < 9; ){
for(; i < 7; i++){
dCurDate = d++;
_td = _cldTabFrm.rows(iRow).cells(i);
_td.disabled = false;
_td.className = "normal";
_td.name = "CURRENTMONTH";
_td.style.backgroundColor = "transparent";
_td.style.border = "0px solid";
if(i == 0 || i == 6) _td.className = "tdHoliday";
if(d - 1 > _monthDays[_dCurMonth]){
dCurDate = dNextMonthDate++;
//_td.disabled = true;
_td.className = "nextMonth";
_td.name = "NEXTMONTH";
}
//if(dCurDate < 10) dCurDate = "0" + dCurDate;
_td.innerHTML = dCurDate;

if(dCurDate == _dCurDate && _td.name == "CURRENTMONTH"){
//_cldTabFrm.rows(iRow).cells(i).style.backgroundColor = "620662";
//_cldTabFrm.rows(iRow).cells(i).background = "bgCurDate.gif";
_cldTabFrm.rows(iRow).cells(i).className = "tdCurDate";
}
if(dCurDate == _dftD.getDate()
&& _dCurMonth == _dftD.getMonth()
&& _dCurYear == _dftD.getFullYear()
&& _td.name == "CURRENTMONTH"){
_cldTabFrm.rows(iRow).cells(i).className = "tdToday";
if(dCurDate == _dCurDate)
_cldTabFrm.rows(iRow).cells(i).className = "tdTodayCurDate";
}
if(dCurDate == _dftD.getDate() && dCurDate == _dCurDate && _td.name == "CURRENTMONTH"){
//_td.style.backgroundColor = "#663366";
//_td.style.border = "1px solid gray";
//_cldTabFrm.rows(iRow).cells(i).className = "tdTodayCurDate";
}

}
i = 0;
iRow++;
}
}
function placeCldTabFrm(){

var _rect = this._rltvO.getBoundingClientRect();
var _bodyWidth = document.body.clientWidth;
var _bodyHeight = document.body.clientHeight;

var _tmp = _cldTabIFrame;
//alert(_bodyHeight);
_cldTabIFrame = _cldTabIFrame2;

var _innerTabFrmRect = _cldTabFrm.getBoundingClientRect();
//_debug(_innerTabFrmRect.right + "," + _innerTabFrmRect.left)

_cldTabIFrame2.style.pixelWidth = /*_innerTabFrmRect.right - _innerTabFrmRect.left*/  220 + (_bBrowserVer55 ? 0 : _nShadowLength);
_cldTabIFrame2.style.pixelHeight = /*_innerTabFrmRect.bottom - _innerTabFrmRect.top*/ 165+ (_bBrowserVer55 ? 0 : _nShadowLength);

_cldTabIFrame.style.pixelLeft = _rect.left - 2 + document.body.scrollLeft;
_cldTabIFrame.style.pixelTop = _rect.bottom - 2 + document.body.scrollTop;

var _cldTabFrmRect = _cldTabIFrame.getBoundingClientRect();

if(_cldTabFrmRect.right > _bodyWidth){
_cldTabIFrame.style.pixelLeft -= (_cldTabFrmRect.right - _bodyWidth + _nShadowLength);
}

if(_cldTabFrmRect.bottom > _bodyHeight){
//alert("dd");
_cldTabIFrame.style.pixelTop = _rect.top - _nShadowLength;
_cldTabIFrame.style.pixelTop -= (_cldTabFrmRect.bottom - _cldTabFrmRect.top - document.body.scrollTop);
}

//alert(_cldTabIFrame.style.pixelWidth);
_cldTabIFrame = _tmp;
//if(
}

function whenMouseOverCldTabFrm(){
_bCanHide = false;
}

function whenMouseOutCldTabFrm(){
_bCanHide = true;
}

function getNextDate(year, month, date){
if(date == null) date = 1;
if(date > _monthDays[month + 1]) date = _monthDays[month + 1];
return new Date(year, month + 1, date);
}

function getLastDate(year, month, date){
if(date == null) date = 1;
if(date > _monthDays[month - 1]) date = _monthDays[month - 1];
return new Date(year, month - 1, date);
}
function switchLastMonth(bLast){
if(bLast == null) bLast = true;
var _tmpdate = null;
_tmpdate = bLast ? getLastDate(_dCurYear, _dCurMonth, _dCurDate) : getNextDate(_dCurYear, _dCurMonth, _dCurDate);
//_curCldTabRltvObj.value = _tmpdate.getFullYear() + "-" + (_tmpdate.getMonth() + 1) + "-" + _tmpdate.getDate();
setTargetFormaValue(_tmpdate.getFullYear(), _tmpdate.getMonth() + 1, _tmpdate.getDate());
_bHaveUpdated = false;
//JSCalendar(_curCldTabRltvObj);
fillCldTabFrm(_tmpdate.getFullYear(), _tmpdate.getMonth(), _tmpdate.getDate());;
}
function switchNextMonth(){
switchLastMonth(false);
}
function switchLastYear(){
//_curCldTabRltvObj.value = (_dCurYear * 1 + 1) + "-" + (_dCurMonth + 1) + "-" + _dCurDate;
setTargetFormaValue(_dCurYear * 1 + 1, _dCurMonth * 1 + 1, _dCurDate);
_bHaveUpdated = false;
//JSCalendar(_curCldTabRltvObj);
fillCldTabFrm(_dCurYear * 1 + 1, _dCurMonth * 1, _dCurDate);
}
function switchNextYear(){
//_curCldTabRltvObj.value = (_dCurYear - 1) + "-" + (_dCurMonth + 1) + "-" + _dCurDate;
setTargetFormaValue(_dCurYear * 1 - 1, _dCurMonth * 1 + 1, _dCurDate);
_bHaveUpdated = false;
//JSCalendar(_curCldTabRltvObj);
fillCldTabFrm(_dCurYear * 1 - 1, _dCurMonth * 1, _dCurDate);
}
function whenMouseOverDateItem(){
var e = _cldTabIFrame.event.srcElement;
var _tmpdate = null;
if(e.tagName == "TD"){
if(e.name == "LASTMONTH"){
_tmpdate = getLastDate(_dCurYear, _dCurMonth);
e.title = "Last : " + _tmpdate.getFullYear() + "-" + (_tmpdate.getMonth() + 1) + "-" + e.innerText;
return;
}
if(e.name == "NEXTMONTH"){
_tmpdate = getNextDate(_dCurYear, _dCurMonth);
e.title = "Next : " + _tmpdate.getFullYear() + "-" + (_tmpdate.getMonth() + 1) + "-" + e.innerText;
return;
}

var sCurDate = _dCurYear + "-" + (_dCurMonth + 1) + "-" + e.innerText;
e.title = "当前日期 : " + sCurDate;

e.style.backgroundColor = "#EFEFEF";

}
}

function resetTargetValue(){
//_curCldTabRltvObj.value = ;
_bHaveSelectNewValue = true;
hideCldTabFrm();
}

function setTargetFormaValue(year, month, date){
var _year, _month, _date;
_year = year;
_month = month * 1;
_date = date * 1;
if(_month < 10) _month = "0" + _month;
if(_date < 10) _date = "0" + _date;

_curCldTabRltvObj.value = _year + "-" + _month + "-" + _date;
}

function whenMouseOutDateItem(){
var e = _cldTabIFrame.event.srcElement;
if(e.tagName == "TD")
e.style.backgroundColor = "";
}
function whenClickDateItem(){
var e = _cldTabIFrame.event.srcElement;
var _tmpdate = null;
var _month = null;
var _date = null;
if(e.tagName == "TD"){
_bHaveUpdated = false;
if(e.name == "LASTMONTH"){
_tmpdate = getLastDate(_dCurYear, _dCurMonth);
setTargetFormaValue(_tmpdate.getFullYear(), _tmpdate.getMonth() + 1, e.innerText);
fillCldTabFrm(_tmpdate.getFullYear(), _tmpdate.getMonth(), e.innerText);
/* new */ //JSCalendar(_curCldTabRltvObj);
return;
}
if(e.name == "NEXTMONTH"){
_tmpdate = getNextDate(_dCurYear, _dCurMonth);
setTargetFormaValue(_tmpdate.getFullYear(), _tmpdate.getMonth() + 1, e.innerText);
/* new */ //JSCalendar(_curCldTabRltvObj);
fillCldTabFrm(_tmpdate.getFullYear(), _tmpdate.getMonth(), e.innerText);
return;
}
/*对text的负值加入到onclick事件中 王勇*/
setTargetFormaValue(_dCurYear, _dCurMonth + 1, e.innerText);
_bHaveSelectNewValue = true;
hideCldTabFrm();
}
}

function hideCldTabFrm(){
//try{
if(!_bHaveSelectNewValue)
if(_cldTabIFrame == null || !_bCanHide) return;
//alert(_cldTabIFrame);
var oFiredObj = null;
try{
oFiredObj = event.srcElement;
}catch(e){
oFiredObj = _cldTabIFrame.event.srcElement;
}
if(oFiredObj == _curCldTabRltvObj) return;
//alert(_curCldTabRltvObj);//

_cldTabIFrame2.style.display = "none";
_bHaveUpdated = false;
_bHaveShown = false;
removeShadowDiv();
//alert(_bHaveSelectNewValue);
if(!_bHaveSelectNewValue)
_curCldTabRltvObj.value = _curCldTabRltvObjValue;
//}catch(e){_debug(e.description);}
}

function removeShadowDiv(){
try{
var arrShadowDiv = eval("window.document.arr" + _cldTabFrm.id);
for(var i = 0; i < arrShadowDiv.length; i++)
arrShadowDiv[i].removeNode(true);
}catch(e){_debug(e.description);}
}

function getValidateDate(sDate){
if(sDate == null) return new Date();
if(sDate.indexOf("-") == -1){
if(isNaN(sDate)) return new Date();
if(sDate * 1 > 9999 || sDate * 1 < 1000) return new Date();
return new Date(sDate, 0, 1);
}

var tmp = sDate.split("-");
if(isNaN(tmp[0]) || isNaN(tmp[1]) || isNaN(tmp[2])
|| tmp[0] > 9999 || tmp[0] < 1000
|| tmp[1] > 12 || tmp[1] < 1
|| tmp[2] > 31 || tmp[2] < 1)
return new Date();
return new Date(tmp[0], tmp[1] - 1, tmp[2]);
}

//var tst = getValidateDate("2000-7-310");
//alert(tst.getFullYear() + "-" + (tst.getMonth() + 1) + "-" + tst.getDate());

function createDateBox(sBoxName, sDfltValue){
var _d = getValidateDate(sDfltValue);
var _month = _d.getMonth() + 1;
var _date = _d.getDate();
if(_month * 1 < 10) _month = "0" + _month;
if(_date * 1 < 10) _date = "0" + _date;
sDfltValue = _d.getFullYear() + "-" + _month + "-" + _date;

var _str = "<INPUT READONLY STYLE='border:1px solid gray;text-align:center;cursor:default;' NAME='" + sBoxName + "' VALUE='" + sDfltValue + "' ONCLICK=JSCalendar(this)>";
document.write(_str);
}

function MakeDivShadowEffect(divObj, color, nLength)
{
//alert(divObj);
var tmpstr = "window.document.arr" + divObj.id + " = new Array();";
eval(tmpstr);
//alert( tmpstr );
var arrShadowDiv = eval("window.document.arr" + divObj.id);
//window.document.arrJACKSHANGJIELOVEFEIFEI = new Array();
//var arrShadowDiv = window.document.arrJACKSHANGJIELOVEFEIFEI;
//alert(arrShadowDiv.length);
var _rect = divObj.getBoundingClientRect();
for( i = nLength; i > 0; i --)
{
var rect = _cldTabIFrame.document.createElement( "DIV" );
rect.style.position = "absolute";
rect.style.left = (divObj.style.posLeft + i ) + "px";
rect.style.top = (divObj.style.posTop + i ) + "px";
rect.style.width = divObj.offsetWidth + "px";
rect.style.height = divObj.offsetHeight + "px";
rect.style.backgroundColor = color;
var opacity = 1 - i / (i + 1);
//alert(rect.style.width);
rect.style.filter = 'alpha(opacity=' + (100 * opacity) + ')';
rect.style.zIndex = divObj.style.zIndex - 1;
//alert(divObj.tagName);
//divObj.insertAdjacentElement("beforeEnd", rect);
_cldTabIFrame.document.body.insertBefore(rect);
arrShadowDiv[arrShadowDiv.length] = rect;
//alert( i );
}
}

function _debug(s){
return;
//var o = new Option(s, s);
//_debugLst.add(o);
form1._debugLst.options[form1._debugLst.length] = new Option(s, s, 0, 0);
form1._debugLst.options[form1._debugLst.length - 1].selected = true;
//_debugLst.item(_debugLst.length - 1).selected = true;
}
document.onclick = hideCldTabFrm;
//createCldTabFrm();
//-->
分享到:
评论

相关推荐

    兼容火狐浏览器的js中文日历控件

    JavaScript(简称js)是网页开发中用于实现动态交互的关键语言,它可以创建各种类型的用户界面组件,包括日历控件。这个中文日历控件是用JavaScript编写的,可以在网页上动态生成一个日历界面,用户可以点击选择日期...

    js酒店价格日历_js门票价格日历_javascript价格日历

    此程序是javascript和php开发,提供酒店、门票订购... 此程序中js是驴妈妈上的,我做了些修改,做学习用,精简了代码和功能,只提供酒店和门票,部分提交url请自己修改。php生成日历的类是自己原创的。不足之处请反馈。

    js 日历 js日历 例子 javascript日历

    在Web开发中,JavaScript日历组件的实现主要依赖于JavaScript语言和CSS来完成页面布局和样式设计。本篇将详细介绍如何创建一个简单的JavaScript日历以及涉及的相关知识点。 首先,我们要理解JavaScript的基础知识。...

    html js脚本日历控件

    7. **兼容性**:考虑到浏览器的多样性,编写JavaScript日历控件时需要关注跨浏览器的兼容性问题,确保在不同的浏览器(如Chrome、Firefox、Safari、Edge和IE)上都能正常工作。 在提供的文件名中,"calendar.html"...

    js日历 12种js日历

    在这个主题中,我们主要关注的是“js日历 12种js日历”,这显然是一份包含了多种不同实现方式的JavaScript日历组件集合。 1. **日历组件的基本概念** 日历组件是网页中常见的交互元素,它允许用户选择日期,通常...

    javascript万年日历js

    在实现万年日历中,JavaScript负责处理所有的逻辑计算,如月份天数的判断、闰年的识别、日期的增减等。开发者通常会定义一系列的函数来处理这些核心算法,例如,获取当前日期、计算指定年份和月份的天数、以及切换...

    三款js日历(javascript 日历)

    总的来说,JavaScript日历插件是网页设计中不可或缺的一部分,它们通过丰富的交互和美观的界面,提升了用户的在线体验。通过深入理解并适当地运用这些工具,开发者可以创建出更加吸引人的网页应用。

    javascript中日历控件

    使用js实现一个日历控件,可以选择日期,我们一般注册页面上需要填写的日期比如生日,就会经常遇到这样的控件,使用起来很简单,只要你把上述文件引入到html或者jsp文件的合适位置即可

    javascript中文日历插件,转换为中文日期

    js插件,实现中文日期的转换,日期转换为中文日期,属相等诸多功能。

    纯JS日历表格

    本项目“纯JS日历表格”旨在提供一个完全使用JavaScript实现的日历视图,允许开发者轻松集成到自己的应用中,进行定制化开发。 日历功能在许多网站和应用程序中都是必不可少的,例如事件管理、预约系统或时间跟踪...

    JavaScript日历

    JavaScript日历是一种基于Web的交互式日历组件,通常用于网页应用中,用户可以通过它查看日期、安排事件或进行时间管理。在JavaScript中创建日历涉及到DOM操作、事件处理、日期对象处理等多个方面。下面我们将深入...

    日文版javascript日历

    【标题】"日文版javascript日历"是一个专门针对日语环境设计的JavaScript日历控件,它提供了方便的日历显示和交互功能,尤其适用于需要日文日期展示的Web应用程序。这个控件不仅包含了完整的日历功能,还带有详细的...

    JS.rar_javascript 日历_js_日历 java

    在本示例中,"JS.rar_javascript 日历_js_日历 java" 提供了一个关于JavaScript日历功能的实现,这通常用于网页中的日期选择器,让用户能够方便地选取日期。 日历组件是Web开发中常见的交互元素,特别是在表单中...

    js日历记事器js动态记事日历漂亮

    总结来说,这个压缩包提供了一个完整的JavaScript日历记事器,包括了前端展示所需的HTML、CSS和JS文件,以及必要的图片资源和用户指南。通过解压并运行index.htm,用户可以在本地浏览器中查看和测试这个日历组件的...

    JavaScript日历控件 六种日历

    JavaScript日历控件是网页开发中常用的一种交互元素,它能帮助用户方便地选择日期,常见于表单输入、事件安排或时间相关的功能。在给定的资源中,包含了六种不同样式的JavaScript日历,这些日历可能具有不同的设计...

    .net中js日历文件

    总结,使用JavaScript日历文件在.NET中实现日期选择功能,主要涉及前端JavaScript库的引入、HTML元素的设置、JavaScript代码的编写以及与服务器端的通信。理解这些基本概念和操作,能帮助你有效地集成和使用JS日历...

    javascript小巧日历插件

    以下将详细介绍JavaScript日历插件的基本原理、核心功能以及如何使用。 首先,日历插件的核心是JavaScript代码,这里是`calendar.js`文件。这个文件包含了实现日历功能的主要逻辑,包括计算日期、展示日历视图、...

    百度日历JS版本,样式完全一致

    "百度日历JS版本"是一个基于JavaScript实现的日历控件,它旨在为用户提供与百度官方日历相似的视觉体验和功能。在这个项目中,我们可以看到四个主要组成部分:`css`、`image`、`index.html`和`js`,这些文件共同构建...

    js日历大全(收积几种JS日历)

    JS日历控件是前端开发中常见的一种组件,主要用于显示日期选择器,用户可以通过它方便地选取日期。本文将详细介绍几种常见的JS日历控件及其应用。 1. **jQuery UI Datepicker** jQuery UI 是一个基于 jQuery 的...

    js完美日历插件

    创建一个完美的JavaScript日历插件涉及多个技术点: 1. **DOM操作**:首先,我们需要在HTML中创建一个容器元素来承载日历显示,然后通过JavaScript对DOM进行操作,动态生成日历的结构,包括月份、星期和日期。 2. ...

Global site tag (gtag.js) - Google Analytics