当柳上原的风吹向天际的时候...

真正的快乐来源于创造

  BlogJava :: 首页 :: 联系 :: 聚合  :: 管理
  368 Posts :: 1 Stories :: 201 Comments :: 0 Trackbacks
当一个div是以绝对定位方式,采用display="block"方式将其显示时,会发生select框出现在div上方的情况,这时的解决办法是在div放置一个iframe,具体代码如下(粗体部分是不被select遮挡的核心代码,另需要注意的是,有时要用JavaScript调整iframe的高度和宽度!):

<%@ page contentType="text/html; charset=UTF-8"%>
<%@ taglib uri="/WEB-INF/tld/struts-html.tld" prefix="html"%>
<%@ taglib uri="/WEB-INF/tld/struts-logic.tld" prefix="logic"%>
<%@ taglib uri="/WEB-INF/tld/struts-bean.tld" prefix="bean"%>
<%@ taglib uri="/WEB-INF/tld/struts-tiles.tld" prefix="tiles"%>

<div id="popupCalender" onmouseover="keepCalendar()" onmouseout="hideCalendar()">
    
<iframe  style="position:absolute;z-index:-1;width:100%;height:100%;top:0;left:0;scrolling:no;" frameborder="0" src="about:blank">
    
</iframe>
  <!-- 这里是核心代码 -->

    
<div>
        
<table border=0 width="100%"  align="center">
            
<tr>
                
<td align="center"><href="javascript:fetchCalendar(-12)">去年</a></td>
                
<td align="center"><href="javascript:fetchCalendar(-1)">上月</a></td>
                
<td align="center"><span id="yearmonth">1</span></td>
                
<td align="center"><href="javascript:fetchCalendar(1)">下月</a></td>
                
<td align="center"><href="javascript:fetchCalendar(12)">来年</a></td>
            
</tr>
        
</table>
        
<span id="timeSpan" class="feedbackHide"></span><span id="offsetSpan" class="feedbackHide">0</span><span id="textBoxNameSpan" class="feedbackHide">12</span>
    
</div>
    
<div>
        
<table class="calendarTable" width="100%" cellspacing="0">
            
<thead>
                
<tr>
                    
<th align="center"></th>
                    
<th align="center"></th>
                    
<th align="center"></th>
                    
<th align="center"></th>
                    
<th align="center"></th>
                    
<th align="center"></th>
                    
<th align="center"></th>
                
</tr>
            
</thead>
            
<tbody id="todoTable"/>
                        
        
</table>
    
</div>
    
<div>
        
<table border="0" >
            
<tr>
                
<td>时间:</td>
                
<td><input type="text" id="currTime" value="12:00:00" size="20" maxlength="20"/></td>
            
</tr>
        
</table>
    
</div>
</div>

<script language="javascript">
<!--
/*********************************************************************
*  显示日历
*  何杨,2011年4月13日19:44:30
********************************************************************
*/
function popupCalendar(img,textBoxName){
    
// get the date in the textbox
    var dateInTextBox=$(textBoxName).value;
    
var pattern=/^ *(\d{4})-(\d{1,2})-(\d{1,2})*$/;
    
    
var regex=new RegExp(pattern);
    
if(regex.test(dateInTextBox)==true){
        
var arr=pattern.exec(dateInTextBox);
        
var year=arr[1];
        
var month=arr[2];
        
var yearmonth=year+"."+month;
        $(
"yearmonth").firstChild.nodeValue=yearmonth;
    }
else{
        
var myDate=new Date();
        
var year=myDate.getFullYear();
        
var month=myDate.getMonth()+1;
        
var yearmonth=year+"."+month;
        $(
"yearmonth").firstChild.nodeValue=yearmonth;
    }

    $(
"textBoxNameSpan").firstChild.nodeValue=textBoxName;

    
var x=getElementPos(textBoxName).x-170;
    
var y=getElementPos(textBoxName).y+20    ;    

    
var popupCalender=$("popupCalender");
    
    popupCalender.style.display
= "block";
    popupCalender.style.left 
= x;
    popupCalender.style.top 
= y; 
    
    
var offset=$("offsetSpan").firstChild.nodeValue;
    
    fetchCalendar(offset);
}

/*****************************************************
* 保持日历,
* 何杨  2010年10月5日19:58:12
****************************************************
*/
function keepCalendar(){
    
var popupCalender=$("popupCalender");
    
    popupCalender.style.display
= "block";
}

/*****************************************************
* 隐藏日历,
* 何杨  2010年10月5日19:58:12
****************************************************
*/
function hideCalendar(){
    
var popupCalender=$("popupCalender");
    
    popupCalender.style.display
= "none";
}

/*****************************************************
* 取得日历,
* 何杨  2010年10月5日19:58:12
****************************************************
*/
function fetchCalendar(offset){
    
var yearmonth=$("yearmonth").firstChild.nodeValue;

    
    yearmonth
=getOffsettedMonth(yearmonth,offset);
    $(
"yearmonth").innerHTML=yearmonth;

    
var table=new MyTable("todoTable");
    table.clear();
    
    
var arr=getCalendarArray(yearmonth);

    table.appendRow(createTodoRowBy(arr,
0,6));    
    table.appendRow(createTodoRowBy(arr,
7,13));    
    table.appendRow(createTodoRowBy(arr,
14,20));    
    table.appendRow(createTodoRowBy(arr,
21,27));    
    table.appendRow(createTodoRowBy(arr,
28,34));    
    table.appendRow(createTodoRowBy(arr,
35,41));    
}

/*****************************************************
* 创建表格行,
* 何杨  2010年10月5日20:26:39
****************************************************
*/
function createTodoRowBy(arr,startIndex,endIndex){
    
// Create Row
    var row=document.createElement("tr");    

    
for(var i=startIndex;i<=endIndex;i++){
        
var text=arr[i];
        
        
if(text=="_"){
            text
=" ";
            row.appendChild(createTextTd(text));
        }
        
else{
            
var imageUrl="web/img/calendar/"+text+".gif";
            
var td=createImageLinkTd(imageUrl,"javascript:showDateInParentTextbox("+text+")");
            
            row.appendChild(td);
        }
    }
        
    
return row;     
}

/*****************************************************
* 在父窗体的文本框中显示日期,
* 何杨  2010年10月5日20:27:06
****************************************************
*/
function showDateInParentTextbox(day){
    
var yearmonth=$("yearmonth").firstChild.nodeValue;
    
    
var pattern=/^ *(\d{4})[.](\d{1,2})*$/;
    
var arr=pattern.exec(yearmonth);

    
var year=parseInt(arr[1]);
    
var month=parseInt(arr[2]);
    
    
if(month<10){
        month
="0"+month;
    }
    
    
if(day<10){
        day
="0"+day;
    }
    
    
var date=year+"-"+month+"-"+day;
    
    
var textBoxName=$("textBoxNameSpan").firstChild.nodeValue;
    
    
var time=$("currTime").value;

    
if(isTime(time)){
        $(textBoxName).value
=date+" "+time;
        hideCalendar();
    }
    
else{
        $(
"currTime").focus();
    }
}


//-->
</script>

popupCalender的CSS设置如下:
#popupCalender{
    display
:none;
    position
:absolute;
    z-index
:3;
    
    padding-top
:0px;
    padding-bottom
:0px;
    padding-left
:0px;
    padding-right
:0px;
    
    width
:360;
    height
:330;
    background-color
:#dcdde0;
    
    border-top
:1px solid #000000;          
    border-left
:1px solid #000000;      
    border-right
:1px solid #000000;   
    border-bottom
:1px solid #000000;      
}

使用效果如下图:
posted on 2011-05-29 12:55 何杨 阅读(2341) 评论(0)  编辑  收藏

只有注册用户登录后才能发表评论。


网站导航: