- 浏览: 1150993 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
RebeccaZhong:
严重: StandardWrapper.Throwableco ...
三步发布java方式的rest服务 -
RebeccaZhong:
严重: StandardWrapper.Throwableco ...
三步发布java方式的rest服务 -
冷酷月光:
楼主。请教一下。arcgis for android 有提供地 ...
ArcGIS API For Android离线地图的实现 -
winney117:
请问如何GET已有网页上的指定内容?比如百度文库中的某一篇文章 ...
三步发布java方式的rest服务 -
zige1012:
您好,我想问问我想换个自己地图的切片,也有4层(L0-L3), ...
ArcGIS API For Android离线地图的实现
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head> <title></title> <meta name="GENERATOR" content="Microsoft Visual Studio .NET 7.1"> <meta name="ProgId" content="VisualStudio.HTML"> <meta name="Originator" content="Microsoft Visual Studio .NET 7.1"> <script language="javascript"> /** *本日历选择控件由tiannet根据前人经验完善而得。大部分代码来自meizz的日历控件。 *tiannet添加了时间选择功能、select,object标签隐藏功能,还有其它小功能。 *使用方法: * (1)只选择日期 <input type="text" name="date" readOnly onClick="setDay(this);"> * (2)选择日期和小时 <input type="text" name="dateh" readOnly onClick="setDayH(this);"> * (3)选择日期和小时及分钟 <input type="text" name="datehm" readOnly onClick="setDayHM(this);"> *设置参数的方法 * (1)设置日期分隔符 setDateSplit(strSplit);默认为"-" * (2)设置日期与时间之间的分隔符 setDateTimeSplit(strSplit);默认为" " * (3)设置时间分隔符 setTimeSplit(strSplit);默认为":" * (4)设置(1),(2),(3)中的分隔符 setSplit(strDateSplit,strDateTimeSplit,strTimeSplit); * (5)设置开始和结束年份 setYearPeriod(intDateBeg,intDateEnd) *说明: * 默认返回的日期时间格式如同:2005-02-02 08:08 */ //------------------ 样式定义 ---------------------------// //功能按钮同样样式 var s_tiannet_turn_base = "height:16px;font-size:9pt;color:white;border:0 solid #CCCCCC;cursor:hand;background-color:#2650A6;"; //翻年、月等的按钮 var s_tiannet_turn = "width:28px;" + s_tiannet_turn_base; //关闭、清空等按钮样式 var s_tiannet_turn2 = "width:22px;" + s_tiannet_turn_base; //年选择下拉框 var s_tiannet_select = "width:64px;display:none;"; //月、时、分选择下拉框 var s_tiannet_select2 = "width:46px;display:none;"; //日期选择控件体的样式 var s_tiannet_body = "width:150;background-color:#2650A6;display:none;z-index:9998;position:absolute;" + "border-left:1 solid #CCCCCC;border-top:1 solid #CCCCCC;border-right:1 solid #999999;border-bottom:1 solid #999999;"; //显示日的td的样式 var s_tiannet_day = "width:21px;height:20px;background-color:#D8F0FC;font-size:10pt;"; //字体样式 var s_tiannet_font = "color:#FFCC00;font-size:9pt;cursor:hand;"; //链接的样式 var s_tiannet_link = "text-decoration:none;font-size:9pt;color:#2650A6;"; //横线 var s_tiannet_line = "border-bottom:1 solid #6699CC"; //------------------ 变量定义 ---------------------------// var tiannetYearSt = 1950;//可选择的开始年份 var tiannetYearEnd = 2010;//可选择的结束年份 var tiannetDateNow = new Date(); var tiannetYear = tiannetDateNow.getFullYear(); //定义年的变量的初始值 var tiannetMonth = tiannetDateNow.getMonth()+1; //定义月的变量的初始值 var tiannetDay = tiannetDateNow.getDate(); var tiannetHour = 8;//tiannetDateNow.getHours(); var tiannetMinute = 0;//tiannetDateNow.getMinutes(); var tiannetArrDay=new Array(42); //定义写日期的数组 var tiannetDateSplit = "-"; //日期的分隔符号 var tiannetDateTimeSplit = " "; //日期与时间之间的分隔符 var tiannetTimeSplit = ":"; //时间的分隔符号 var tiannetOutObject; //接收日期时间的对象 var arrTiannetHide = new Array();//被强制隐藏的标签 var m_bolShowHour = false;//是否显示小时 var m_bolShowMinute = false;//是否显示分钟 var m_aMonHead = new Array(12); //定义阳历中每个月的最大天数 m_aMonHead[0] = 31; m_aMonHead[1] = 28; m_aMonHead[2] = 31; m_aMonHead[3] = 30; m_aMonHead[4] = 31; m_aMonHead[5] = 30; m_aMonHead[6] = 31; m_aMonHead[7] = 31; m_aMonHead[8] = 30; m_aMonHead[9] = 31; m_aMonHead[10] = 30; m_aMonHead[11] = 31; // ---------------------- 用户可调用的函数 -----------------------------// //用户主调函数-只选择日期 function setDay(obj){ tiannetOutObject = obj; //如果标签中有值,则将日期初始化为当前值 var strValue = tiannetTrim(tiannetOutObject.value); if( strValue != "" ){ tiannetInitDate(strValue); } tiannetPopCalendar(); } //用户主调函数-选择日期和小时 function setDayH(obj){ tiannetOutObject = obj; m_bolShowHour = true; //如果标签中有值,则将日期和小时初始化为当前值 var strValue = tiannetTrim(tiannetOutObject.value); if( strValue != "" ){ tiannetInitDate(strValue.substring(0,10)); var hour = strValue.substring(11,13); if( hour < 10 ) tiannetHour = hour.substring(1,2); } tiannetPopCalendar(); } //用户主调函数-选择日期和小时及分钟 function setDayHM(obj){ tiannetOutObject = obj; m_bolShowHour = true; m_bolShowMinute = true; //如果标签中有值,则将日期和小时及分钟初始化为当前值 var strValue = tiannetTrim(tiannetOutObject.value); if( strValue != "" ){ tiannetInitDate(strValue.substring(0,10)); var time = strValue.substring(11,16); var arr = time.split(tiannetTimeSplit); tiannetHour = arr[0]; tiannetMinute = arr[1]; if( tiannetHour < 10 ) tiannetHour = tiannetHour.substring(1,2); if( tiannetMinute < 10 ) tiannetMinute = tiannetMinute.substring(1,2); } tiannetPopCalendar(); } //设置开始日期和结束日期 function setYearPeriod(intDateBeg,intDateEnd){ tiannetYearSt = intDateBeg; tiannetYearEnd = intDateEnd; } //设置日期分隔符。默认为"-" function setDateSplit(strDateSplit){ tiannetDateSplit = strDateSplit; } //设置日期与时间之间的分隔符。默认为" " function setDateTimeSplit(strDateTimeSplit){ tiannetDateTimeSplit = strDateTimeSplit; } //设置时间分隔符。默认为":" function setTimeSplit(strTimeSplit){ tiannetTimeSplit = strTimeSplit; } //设置分隔符 function setSplit(strDateSplit,strDateTimeSplit,strTimeSplit){ tiannetDateSplit(strDateSplit); tiannetDateTimeSplit(strDateTimeSplit); tiannetTimeSplit(strTimeSplit); } //设置默认的日期。格式为:YYYY-MM-DD function setDefaultDate(strDate){ tiannetYear = strDate.substring(0,4); tiannetMonth = strDate.substring(5,7); tiannetDay = strDate.substring(8,10); } //设置默认的时间。格式为:HH24:MI function setDefaultTime(strTime){ tiannetHour = strTime.substring(0,2); tiannetMinute = strTime.substring(3,5); } // ---------------------- end 用户可调用的函数 -----------------------------// //------------------ begin 页面显示部分 ---------------------------// var weekName = new Array("日","一","二","三","四","五","六"); document.write('<div id="divTiannetDate" style="'+s_tiannet_body+'" style="本日历选择控件由tiannet根据前人经验完善而成!">'); document.write('<div align="center" id="divTiannetDateText" Author="tiannet" style="padding-top:2px;">'); document.write('<span id="tiannetYearHead" Author="tiannet" style="'+s_tiannet_font+'" '+ 'onclick="spanYearCEvent();"> 年</span>'); document.write('<select id="selTianYear" style="'+s_tiannet_select+'" Author="tiannet" '+ ' onChange="tiannetYear=this.value;tiannetSetDay(tiannetYear,tiannetMonth);document.all.tiannetYearHead.style.display=\'\';'+ 'this.style.display=\'none\';">'); for(var i=tiannetYearSt;i <= tiannetYearEnd;i ++){ document.writeln('<option value="' + i + '">' + i + '年</option>'); } document.write('</select>'); document.write('<span id="tiannetMonthHead" Author="tiannet" style="'+s_tiannet_font+'" '+ 'onclick="spanMonthCEvent();"> 月</span>'); document.write('<select id="selTianMonth" style="'+s_tiannet_select2+'" Author="tiannet" '+ 'onChange="tiannetMonth=this.value;tiannetSetDay(tiannetYear,tiannetMonth);document.all.tiannetMonthHead.style.display=\'\';'+ 'this.style.display=\'none\';">'); for(var i=1;i <= 12;i ++){ document.writeln('<option value="' + i + '">' + i + '月</option>'); } document.write('</select>'); //document.write('</div>'); //document.write('<div align="center" id="divTiannetTimeText" Author="tiannet">'); document.write('<span id="tiannetHourHead" Author="tiannet" style="'+s_tiannet_font+'display:none;" '+ 'onclick="spanHourCEvent();"> 时</span>'); document.write('<select id="selTianHour" style="'+s_tiannet_select2+'display:none;" Author="tiannet" '+ ' onChange="tiannetHour=this.value;tiannetWriteHead();document.all.tiannetHourHead.style.display=\'\';' + 'this.style.display=\'none\';">'); for(var i=0;i <= 23;i ++){ document.writeln('<option value="' + i + '">' + i + '时</option>'); } document.write('</select>'); document.write('<span id="tiannetMinuteHead" Author="tiannet" style="'+s_tiannet_font+'display:none;" '+ 'onclick="spanMinuteCEvent();"> 分</span>'); document.write('<select id="selTianMinute" style="'+s_tiannet_select2+'display:none;" Author="tiannet" '+ ' onChange="tiannetMinute=this.value;tiannetWriteHead();document.all.tiannetMinuteHead.style.display=\'\';'+ 'this.style.display=\'none\';">'); for(var i=0;i <= 59;i ++){ document.writeln('<option value="' + i + '">' + i + '分</option>'); } document.write('</select>'); document.write('</div>'); //输出一条横线 document.write('<div style="'+s_tiannet_line+'"></div>'); document.write('<div align="center" id="divTiannetTurn" style="border:0;" Author="tiannet">'); document.write('<input type="button" style="'+s_tiannet_turn+'" value="年↑" title="上一年" onClick="tiannetPrevYear();">'); document.write('<input type="button" style="'+s_tiannet_turn+'" value="年↓" title="下一年" onClick="tiannetNextYear();"> '); document.write('<input type="button" style="'+s_tiannet_turn+'" value="月↑" title="上一月" onClick="tiannetPrevMonth();">'); document.write('<input type="button" style="'+s_tiannet_turn+'" value="月↓" title="下一月" onClick="tiannetNextMonth();">'); document.write('</div>'); //输出一条横线 document.write('<div style="'+s_tiannet_line+'"></div>'); document.write('<table border=0 cellspacing=0 cellpadding=0 bgcolor=white onselectstart="return false">'); document.write(' <tr style="background-color:#2650A6;font-size:10pt;color:white;height:22px;" Author="tiannet">'); for(var i =0;i < weekName.length;i ++){ //输出星期 document.write('<td width="21" align="center" Author="tiannet">' + weekName[i] + '</td>'); } document.write(' </tr>'); document.write('</table>'); //输出天的选择 document.write('<table border=0 cellspacing=1 cellpadding=0 bgcolor=white onselectstart="return false">'); var n = 0; for (var i=0;i<5;i++) { document.write (' <tr align=center id="trTiannetDay' + i + '" >'); for (var j=0;j<7;j++){ document.write('<td align="center" id="tdTiannetDay' + n + '" '+ 'onClick="tiannetDay=this.innerText;tiannetSetValue(true);" ' +' style="' + s_tiannet_day + '"> </td>'); n ++; } document.write (' </tr>'); } document.write (' <tr align=center id="trTiannetDay5" >'); document.write('<td align="center" id="tdTiannetDay35" onClick="tiannetDay=this.innerText;tiannetSetValue(true);" ' +' style="' + s_tiannet_day + '"> </td>'); document.write('<td align="center" id="tdTiannetDay36" onClick="tiannetDay=this.innerText;tiannetSetValue(true);" ' +' style="' + s_tiannet_day + '"> </td>'); document.write('<td align="right" colspan="5"><a href="javascript:tiannetClear();" style="' + s_tiannet_link + '">清空</a>'+ ' <a href="javascript:tiannetHideControl();" style="' + s_tiannet_link + '">关闭</a>' + ' <a href="javascript:tiannetSetValue(true);" style="' + s_tiannet_link + '">确定</a> ' + '</td>'); document.write (' </tr>'); document.write('</table>'); document.write('</div>'); //------------------ end 页面显示部分 ---------------------------// //------------------ 显示日期时间的span标签响应事件 ---------------------------// //单击年份span标签响应 function spanYearCEvent(){ hideElementsById(new Array("selTianYear","tiannetMonthHead"),false); if(m_bolShowHour) hideElementsById(new Array("tiannetHourHead"),false); if(m_bolShowMinute) hideElementsById(new Array("tiannetMinuteHead"),false); hideElementsById(new Array("tiannetYearHead","selTianMonth","selTianHour","selTianMinute"),true); } //单击月份span标签响应 function spanMonthCEvent(){ hideElementsById(new Array("selTianMonth","tiannetYearHead"),false); if(m_bolShowHour) hideElementsById(new Array("tiannetHourHead"),false); if(m_bolShowMinute) hideElementsById(new Array("tiannetMinuteHead"),false); hideElementsById(new Array("tiannetMonthHead","selTianYear","selTianHour","selTianMinute"),true); } //单击小时span标签响应 function spanHourCEvent(){ hideElementsById(new Array("tiannetYearHead","tiannetMonthHead"),false); if(m_bolShowHour) hideElementsById(new Array("selTianHour"),false); if(m_bolShowMinute) hideElementsById(new Array("tiannetMinuteHead"),false); hideElementsById(new Array("tiannetHourHead","selTianYear","selTianMonth","selTianMinute"),true); } //单击分钟span标签响应 function spanMinuteCEvent(){ hideElementsById(new Array("tiannetYearHead","tiannetMonthHead"),false); if(m_bolShowHour) hideElementsById(new Array("tiannetHourHead"),false); if(m_bolShowMinute) hideElementsById(new Array("selTianMinute"),false); hideElementsById(new Array("tiannetMinuteHead","selTianYear","selTianMonth","selTianHour"),true); } //根据标签id隐藏或显示标签 function hideElementsById(arrId,bolHide){ var strDisplay = ""; if(bolHide) strDisplay = "none"; for(var i = 0;i < arrId.length;i ++){ var obj = document.getElementById(arrId[i]); obj.style.display = strDisplay; } } //------------------ end 显示日期时间的span标签响应事件 ---------------------------// //判断某年是否为闰年 function isPinYear(year){ var bolRet = false; if (0==year%4&&((year%100!=0)||(year%400==0))) { bolRet = true; } return bolRet; } //得到一个月的天数,闰年为29天 function getMonthCount(year,month){ var c=m_aMonHead[month-1]; if((month==2)&&isPinYear(year)) c++; return c; } //重新设置当前的日。主要是防止在翻年、翻月时,当前日大于当月的最大日 function setRealDayCount() { if( tiannetDay > getMonthCount(tiannetYear,tiannetMonth) ) { //如果当前的日大于当月的最大日,则取当月最大日 tiannetDay = getMonthCount(tiannetYear,tiannetMonth); } } //在个位数前加零 function addZero(value){ if(value < 10 ){ value = "0" + value; } return value; } //取出空格 function tiannetTrim(str) { return str.replace(/(^\s*)|(\s*$)/g,""); } //为select创建一个option function createOption(objSelect,value,text){ var option = document.createElement("OPTION"); option.value = value; option.text = text; objSelect.options.add(option); } //往前翻 Year function tiannetPrevYear() { if(tiannetYear > 999 && tiannetYear <10000){tiannetYear--;} else{alert("年份超出范围(1000-9999)!");} tiannetSetDay(tiannetYear,tiannetMonth); //如果年份小于允许的最小年份,则创建对应的option if( tiannetYear < tiannetYearSt ) { tiannetYearSt = tiannetYear; createOption(document.all.selTianYear,tiannetYear,tiannetYear + "年"); } checkSelect(document.all.selTianYear,tiannetYear); tiannetWriteHead(); } //往后翻 Year function tiannetNextYear() { if(tiannetYear > 999 && tiannetYear <10000){tiannetYear++;} else{alert("年份超出范围(1000-9999)!");return;} tiannetSetDay(tiannetYear,tiannetMonth); //如果年份超过允许的最大年份,则创建对应的option if( tiannetYear > tiannetYearEnd ) { tiannetYearEnd = tiannetYear; createOption(document.all.selTianYear,tiannetYear,tiannetYear + "年"); } checkSelect(document.all.selTianYear,tiannetYear); tiannetWriteHead(); } //选择今天 function tiannetToday() { tiannetYear = tiannetDateNow.getFullYear(); tiannetMonth = tiannetDateNow.getMonth()+1; tiannetDay = tiannetDateNow.getDate(); tiannetSetValue(true); //tiannetSetDay(tiannetYear,tiannetMonth); //selectObject(); } //往前翻月份 function tiannetPrevMonth() { if(tiannetMonth>1){tiannetMonth--}else{tiannetYear--;tiannetMonth=12;} tiannetSetDay(tiannetYear,tiannetMonth); checkSelect(document.all.selTianMonth,tiannetMonth); tiannetWriteHead(); } //往后翻月份 function tiannetNextMonth() { if(tiannetMonth==12){tiannetYear++;tiannetMonth=1}else{tiannetMonth++} tiannetSetDay(tiannetYear,tiannetMonth); checkSelect(document.all.selTianMonth,tiannetMonth); tiannetWriteHead(); } //向span标签中写入年、月、时、分等数据 function tiannetWriteHead(){ document.all.tiannetYearHead.innerText = tiannetYear + "年"; document.all.tiannetMonthHead.innerText = tiannetMonth + "月"; if( m_bolShowHour ) document.all.tiannetHourHead.innerText = " "+tiannetHour + "时"; if( m_bolShowMinute ) document.all.tiannetMinuteHead.innerText = tiannetMinute + "分"; tiannetSetValue(false);//给文本框赋值,但不隐藏本控件 } //设置显示天 function tiannetSetDay(yy,mm) { setRealDayCount();//设置当月真实的日 tiannetWriteHead(); var strDateFont1 = "", strDateFont2 = "" //处理日期显示的风格 for (var i = 0; i < 37; i++){tiannetArrDay[i]=""}; //将显示框的内容全部清空 var day1 = 1; var firstday = new Date(yy,mm-1,1).getDay(); //某月第一天的星期几 for (var i = firstday; day1 < getMonthCount(yy,mm)+1; i++){ tiannetArrDay[i]=day1;day1++; } //如果用于显示日的最后一行的第一个单元格的值为空,则隐藏整行。 //if(tiannetArrDay[35] == ""){ // document.all.trTiannetDay5.style.display = "none"; //} else { // document.all.trTiannetDay5.style.display = ""; //} for (var i = 0; i < 37; i++){ var da = eval("document.all.tdTiannetDay"+i) //书写新的一个月的日期星期排列 if (tiannetArrDay[i]!="") { //判断是否为周末,如果是周末,则改为红色字体 if(i % 7 == 0 || (i+1) % 7 == 0){ strDateFont1 = "<font color=#f0000>" strDateFont2 = "</font>" } else { strDateFont1 = ""; strDateFont2 = "" } da.innerHTML = strDateFont1 + tiannetArrDay[i] + strDateFont2; //如果是当前选择的天,则改变颜色 if(tiannetArrDay[i] == tiannetDay ) { da.style.backgroundColor = "#CCCCCC"; } else { da.style.backgroundColor = "#EFEFEF"; } da.style.cursor="hand" } else { da.innerHTML="";da.style.backgroundColor="";da.style.cursor="default" } }//end for tiannetSetValue(false);//给文本框赋值,但不隐藏本控件 }//end function tiannetSetDay //根据option的值选中option function checkSelect(objSelect,selectValue) { var count = parseInt(objSelect.length); if( selectValue < 10 && selectValue.toString().length == 2) { selectValue = selectValue.substring(1,2); } for(var i = 0;i < count;i ++){ if(objSelect.options[i].value == selectValue){ objSelect.selectedIndex = i; break; } }//for } //选中年、月、时、分等下拉框 function selectObject(){ //如果年份小于允许的最小年份,则创建对应的option if( tiannetYear < tiannetYearSt ) { for( var i = tiannetYear;i < tiannetYearSt;i ++ ){ createOption(document.all.selTianYear,i,i + "年"); } tiannetYearSt = tiannetYear; } //如果年份超过允许的最大年份,则创建对应的option if( tiannetYear > tiannetYearEnd ) { for( var i = tiannetYearEnd+1;i <= tiannetYear;i ++ ){ createOption(document.all.selTianYear,i,i + "年"); } tiannetYearEnd = tiannetYear; } checkSelect(document.all.selTianYear,tiannetYear); checkSelect(document.all.selTianMonth,tiannetMonth); if( m_bolShowHour ) checkSelect(document.all.selTianHour,tiannetHour); if( m_bolShowMinute ) checkSelect(document.all.selTianMinute,tiannetMinute); } //给接受日期时间的控件赋值 //参数bolHideControl - 是否隐藏控件 function tiannetSetValue(bolHideControl){ var value = ""; if( !tiannetDay || tiannetDay == "" ){ tiannetOutObject.value = value; return; } var mm = tiannetMonth; var day = tiannetDay; if( mm < 10 && mm.toString().length == 1) mm = "0" + mm; if( day < 10 && day.toString().length == 1) day = "0" + day; value = tiannetYear + tiannetDateSplit + mm + tiannetDateSplit + day; if( m_bolShowHour ){ var hour = tiannetHour; if( hour < 10 && hour.toString().length == 1 ) hour = "0" + hour; value += tiannetDateTimeSplit + hour; } if( m_bolShowMinute ){ var minute = tiannetMinute; if( minute < 10 && minute.toString().length == 1 ) minute = "0" + minute; value += tiannetTimeSplit + minute; } tiannetOutObject.value = value; //document.all.divTiannetDate.style.display = "none"; if( bolHideControl ) { tiannetHideControl(); } } //是否显示时间 function showTime(){ if( !m_bolShowHour && m_bolShowMinute){ alert("如果要选择分钟,则必须可以选择小时!"); return; } hideElementsById(new Array("tiannetHourHead","selTianHour","tiannetMinuteHead","selTianMinute"),true); if( m_bolShowHour ){ //显示小时 hideElementsById(new Array("tiannetHourHead"),false); } if( m_bolShowMinute ){ //显示分钟 hideElementsById(new Array("tiannetMinuteHead"),false); } } //弹出显示日历选择控件,以让用户选择 function tiannetPopCalendar(){ //隐藏下拉框,显示相对应的head hideElementsById(new Array("selTianYear","selTianMonth","selTianHour","selTianMinute"),true); hideElementsById(new Array("tiannetYearHead","tiannetMonthHead","tiannetHourHead","tiannetMinuteHead"),false); tiannetSetDay(tiannetYear,tiannetMonth); tiannetWriteHead(); showTime(); var dads = document.all.divTiannetDate.style; var iX, iY; var h = document.all.divTiannetDate.offsetHeight; var w = document.all.divTiannetDate.offsetWidth; //计算left if (window.event.x + h > document.body.offsetWidth - 10 ) iX = window.event.x - h - 5 ; else iX = window.event.x + 5; if (iX <0) iX=0; //计算top iY = window.event.y; if (window.event.y + w > document.body.offsetHeight - 10 ) iY = document.body.scrollTop + document.body.offsetHeight - w - 5 ; else iY = document.body.scrollTop +window.event.y + 5; if (iY <0) iY=0; dads.left = iX; dads.top = iY; tiannetShowControl(); selectObject(); } //隐藏日历控件(同时显示被强制隐藏的标签) function tiannetHideControl(){ document.all.divTiannetDate.style.display = "none"; tiannetShowObject(); arrTiannetHide = new Array();//将被隐藏的标签对象清空 } //显示日历控件(同时隐藏会遮挡的标签) function tiannetShowControl(){ document.all.divTiannetDate.style.display = ""; tiannetHideObject("Select"); tiannetHideObject("OBJECT"); } //根据标签名称隐藏标签。如会遮住控件的select,object function tiannetHideObject(strTagName) { x = document.all.divTiannetDate.offsetLeft; y = document.all.divTiannetDate.offsetTop; h = document.all.divTiannetDate.offsetHeight; w = document.all.divTiannetDate.offsetWidth; for (var i = 0; i < document.all.tags(strTagName).length; i++) { var obj = document.all.tags(strTagName)[i]; if (! obj || ! obj.offsetParent) continue; // 获取元素对于BODY标记的相对坐标 var objLeft = obj.offsetLeft; var objTop = obj.offsetTop; var objHeight = obj.offsetHeight; var objWidth = obj.offsetWidth; var objParent = obj.offsetParent; while (objParent.tagName.toUpperCase() != "BODY"){ objLeft += objParent.offsetLeft; objTop += objParent.offsetTop; objParent = objParent.offsetParent; } //alert("控件左端:" + x + "select左端" + (objLeft + objWidth) + "控件底部:" + (y+h) + "select高:" + objTop); var bolHide = true; if( obj.style.display == "none" || obj.style.visibility == "hidden" || obj.getAttribute("Author") == "tiannet" ){ //如果标签本身就是隐藏的,则不需要再隐藏。如果是控件中的下拉框,也不用隐藏。 bolHide = false; } if( ( (objLeft + objWidth) > x && (y + h + 20) > objTop && (objTop+objHeight) > y && objLeft < (x+w) ) && bolHide ){ //arrTiannetHide.push(obj);//记录被隐藏的标签对象 arrTiannetHide[arrTiannetHide.length] = obj; obj.style.visibility = "hidden"; } } } //显示被隐藏的标签 function tiannetShowObject(){ for(var i = 0;i < arrTiannetHide.length;i ++){ //alert(arrTiannetHide[i]); arrTiannetHide[i].style.visibility = ""; } } //初始化日期。 function tiannetInitDate(strDate){ var arr = strDate.split(tiannetDateSplit); tiannetYear = arr[0]; tiannetMonth = arr[1]; tiannetDay = arr[2]; } //清空 function tiannetClear(){ tiannetOutObject.value = ""; tiannetHideControl(); } //任意点击时关闭该控件 function document.onclick(){ with(window.event.srcElement){ if (tagName != "INPUT" && getAttribute("Author") != "tiannet") tiannetHideControl(); } } //按ESC键关闭该控件 function document.onkeypress(){ if( event.keyCode == 27 ){ tiannetHideControl(); } } </script> </head> <body> (1)只选择日期 <input type="text" name="date" readOnly onClick="setDay(this);"><br/> (2)选择日期和小时 <input type="text" name="dateh" readOnly onClick="setDayH(this);"><br/> (3)选择日期和小时及分钟 <input type="text" name="datehm" readOnly onClick="setDayHM(this);"> </body> </html>
event.srcElement
IE专有:取得当前点击的对象而不必传入参数,getAttribute用于取得自定义对象
<script> function x() { alert(event.srcElement.getAttribute('dd')) } </script> <div onclick=x() dd='自定义值1'>【点我测试】</div> //等效于下面的 <div onclick=alert(this.getAttribute('dd')) dd='自定义值2'>【点我测试】</div>
document.all的意思是文档的所有元素,也就是说它包含了当前网页的所有元素。它是以数组的形式保存元素的属性的,所以我们可以用 document.all["元素名"].属性名="属性值"来动态改变元素的属性。用这条语句,可以做出许许多多动态网页效果,如:动态变换图片、动态改变文本的背景、动态改变网页的背景、动态改变图片的大小、动态改变文字的大小各颜色等等。你简直可以动态控制所有网页元素。
<script language="JavaScript"> function cardClick(cardID){ var obj; for (var i=1;i<7;i++){ obj=document.all("card"+i); obj.style.backgroundColor="#3A6EA5"; obj.style.color="#FFFFFF"; } obj=document.all("card"+cardID); obj.style.backgroundColor="#FFFFFF"; obj.style.color="#3A6EA5"; for (var i=1;i<7;i++){ obj=document.all("content"+i); obj.style.display="none"; } obj=document.all("content"+cardID); obj.style.display=""; } </script>
发表评论
-
EXT新手建议:建立自己的工具箱(Toolkit)
2008-12-11 09:56 2033转自:http://www.iteye.com/topic/1 ... -
JavaScript实现双击编辑
2008-12-09 19:20 3139其实就是元素的替代 <!DOCTYPE html ... -
ExtJS学习笔记 layout的9种样式风格总结
2008-12-08 17:09 35777extjs的容器组件都可以设置它的显示风格,它的有效值有 ab ... -
ExtJS学习笔记二 Tree的Treepanel使用
2008-12-05 11:04 11126最近学习extjs发现了一个问题,extjs是一个Ja ... -
extjs学习资源
2008-12-02 16:49 1942ExtJs官方网 http://www.extjs.com/ ... -
extjs的Tooltips与QuickTips
2008-12-02 16:03 6392ExtJs是通过Ext.ToolTip和Ext.QuickTi ... -
ExtJS学习笔记一 ExtJS开发环境的配置
2008-11-26 11:03 3444<link rel="stylesheet ... -
自定义对象
2008-10-28 14:55 1191一,概述 在Java语言中,我们可以定义自己的类,并根据这些 ... -
javascript this详解
2008-10-28 13:04 1264在面向对象编程语言中,对于this关键字我们是非常熟悉的。比如 ... -
多选图片一次上传
2008-08-18 16:34 8117做上传图片功能的时候,经常会遇到这样一个问题,有时候可能需要一 ... -
使用external实现javscript调用flash的function
2008-08-18 15:22 1562先看Flash帮助的对于addCallback相关说明: p ... -
Javascript与flash交互通信控制的方法
2008-08-18 14:55 3321下面是一些在Flash和使用Javascript的HTML文件 ... -
控制 Flash Player 的 JavaScript 方法一览表
2008-08-18 12:14 4514播放动画:Play() 例:(网页中的 Flash id) ... -
利用数组提高IE拼接字符串效率
2008-08-17 15:54 1549今天终于静下心来研究程序的效率问题,竟然发现一个普通的循环拼接 ... -
多文件上传组件SWFUpload java环境小例子
2008-08-16 23:32 8942前几周做一个web企业项目,用户一定要求要有批量上传功能,而且 ... -
JS三种编解码方式
2008-08-14 12:28 1728js对文字进行编码涉及3个函数:escape,encodeUR ... -
深入JavaScript(apply和call函数)
2008-07-31 14:22 44921、关于javascript的apply和 ... -
关于JavaScript中apply与call的用法意义及区别
2008-07-31 14:12 2754JavaScript中有一个call和ap ... -
prototype实例一则
2008-07-31 13:21 3108为什么我还没有点击链接 zhuanyi函数就运行了。。。 & ... -
javascript中的触发器传递参数
2008-07-31 11:00 3127在一个结构良好的网页 ...
相关推荐
JavaScript时间选择控件是一种在网页上提供用户交互式时间选择功能的组件,通常用于收集用户的日期和时间输入,如在填写表单时选择生日。这种控件通过CSS(层叠样式表)和JavaScript来实现,使得用户界面既美观又...
JavaScript 日期时间控件是一种在Web应用程序中用于用户交互式选择日期和时间的组件。它通常以日历或时钟的图形用户界面呈现,提供了一种直观且易于使用的交互方式,使得用户能够方便地输入或选择日期和时间值。在这...
JavaScript时间选择控件是一种在网页上提供用户交互,用于选取特定时间的UI组件。这种控件通常用于在线表单,允许用户输入或选择日期和时间,以提高数据输入的准确性和用户体验。在JavaScript中实现这样的功能,我们...
JavaScript日期时间选择控件是一种常见的前端开发工具,用于在网页上提供用户友好的日期和时间输入界面。在网页设计中,这种控件可以极大提升用户体验,因为它允许用户通过直观的日历视图和时间选择器来设定日期和...
综上所述,WdatePicker作为一个强大的JavaScript时间选择控件,不仅具备基本的日期选择功能,还提供了丰富的定制选项,极大地提升了用户在网页上的时间输入体验。通过理解和掌握WdatePicker的使用,开发者可以更好地...
JavaScript时间控件是一种在网页上实现用户交互式时间选择功能的工具,通常用于表单输入或者日历插件等场景。这种控件允许用户通过图形界面来选择或输入时间,而不是传统的文本输入框,提高了用户体验和数据准确性。...
综上所述,"jQuery时间选择控件"涉及的知识点涵盖了前端开发的多个方面,包括jQuery插件开发、HTML结构、CSS样式、JavaScript事件处理、动画效果、Ajax交互以及兼容性和调试。在实际开发中,开发者需要综合运用这些...
JavaScript日期时间选择控件是网页开发中常用的一种交互元素,它允许用户在界面上方便地选取日期和时间,常用于表单输入、日程安排或事件预订等场景。本控件通常通过JavaScript库实现,例如jQuery UI、Bootstrap ...
选择日期控件(js封装类,javascript,选择日期,文本框选择日期,控件)
总之,"Calendar"是一款适用于JavaScript开发的日期选择控件,它的易用性和灵活性使其成为网页中常见的时间输入解决方案。掌握其用法和API,结合JavaScript的日期处理知识,能帮助开发者创建更丰富的用户界面。
JavaScript时间日历控件是网页开发中常用的一种组件,它为用户提供了一种直观的方式来选择日期或时间。在Web应用程序中,这种控件可以极大提升用户体验,尤其在处理表单输入或者进行时间相关的交互时。JavaScript...
日期选择时间控件的实现通常基于JavaScript库,例如jQuery UI中的Datepicker或者Bootstrap的Datetimepicker。这些库提供了丰富的功能,如预设日期范围、禁用特定日期、自定义格式化以及多语言支持等。开发者可以根据...
5. **兼容性**:对于跨平台的应用,时间选择控件需要兼容Android和iOS等主流操作系统,同时也要考虑到不同的浏览器和JavaScript库。 6. **事件处理**:当用户完成时间选择后,控件应能触发相应的事件,以便开发者...
在前端开发中,日期和时间控件常用于表单填写、事件预订、日程安排等场景。它们简化了用户输入日期和时间的过程,避免了手动输入可能产生的错误。这种控件通常会提供日历视图,滑块或者下拉菜单供用户选择年、月、日...
本篇文章将深入探讨如何使用JavaScript实现一个高效且用户友好的时间选择控件。 首先,我们需要理解时间选择控件的基本功能。它通常包括年、月、日、小时、分钟的选择,并可能包含秒和时区。为了实现这样的功能,...
`js移动端日期时间选择控件` 是一种常见的交互元素,它允许用户方便地选取日期和时间,提高用户体验。在JavaScript(特别是原生JS)中,我们可以创建自定义的日期时间选择器,或者利用现有的开源库来实现这一功能。 ...
例如,描述中的“日期控件”和“时间控件”就是基于JavaScript实现的,它们不仅可以在桌面端浏览器上运行,也兼容移动端设备,确保了跨平台的可用性。 “自定义”和“易修改”是现代前端开发的重要特性。一个优秀的...
JavaScript 日期选择控件是一种常见的前端开发组件,用于在网页上提供用户友好的日期选取功能。这类控件通常包括日历视图,允许用户通过视觉界面来选择日期,而不是手动输入。在本话题中,我们将深入探讨如何创建或...
封装好的时间控件是开发者通过编程语言(如JavaScript、HTML5和CSS)预先编写并优化过的代码模块,可直接在项目中应用。这种封装使得开发者无需从零开始构建时间选择功能,大大节省了时间和精力。封装通常包括对各种...