亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

完美解決在ModalPopupExtender中使用CalendarExtender時被層遮擋的問題

2024-07-10 13:18:44
字體:
來源:轉載
供稿:網友
大家可以去官方網站查看demo,ModalPopupExtender控件用來在網頁中實現類似于模式對話框的效果,而CalendarExterder控件提供日期輸入,它有幾個很重要的屬性:

TargetControlID:日期輸入的目標控件ID,一般來說都都是一個文本框。
Format:日期格式,如yyyy-MM-dd。
PopupButtonID:用戶打開日期選擇面板的控件ID,如按鈕,圖片等。
PopupPosition:設置日期選擇面板打開的位置,這個是相對于TargetControlID所在控件的位置的。有幾個可選的值:BottomLeft,BottomRight,Left,Right,TopLeft,TopRight。
  一般來說我們只需要設置這幾個屬性就可以滿足應用了,除非你想自定義日期選擇面板的顯示樣式,這時你需要自己給定CssClass。這里是一個例子。

復制代碼 代碼如下:


<asp:TextBox runat="server" CssClass="singleText" MaxLength="10"></asp:TextBox>
<asp:Image ImageUrl="/upload/2009-11/20091124203311125.png" runat="server" />
<ajaxToolkit:CalendarExtender Format="yyyy-MM-dd" TargetControlID="tbBeginTime" PopupButtonID="imgBeginTime" runat="server">
</ajaxToolkit:CalendarExtender>


  網上有人說這個控件打開的日期選擇面板會被下拉列表擋住,好像在早期的版本中會存在這個問題,現在新的版本已經修正了這個bug。我所遇到的問題是在ModelPopupExtender控件中使用CalendarExtender,日期選擇面板會被后面的ModelPopupExtender擋住。有關ModelPopupExtender的使用讀者可以看看官方網站的例子,很簡單,這里我就不多說了??匆幌聠栴}的截圖。

完美解決在ModalPopupExtender中使用CalendarExtender時被層遮擋的問題

看到了吧!CalendarExtender彈出的日期選擇面板被后面的ModelPopupExtender擋住了。我在Google上搜了一些資料,大多都是講怎么重新設置CalendarExtender控件的樣式,指定層的z-inde屬性等,但我嘗試過都失敗了,其中有人說在IE6下測試是可以的,不過我沒有驗證過,因為我現在也找不到裝有IE6的機器了,沒有環境,自然測不了。

  其實在FireFox下用Firebug查看頁面生成的html,你會看到ModelPopupExtender樣式中的z-index和CalendarExtender是相同的,這估計是Ajax Toolkit控件中的一個bug,應該所有類似于這樣的控件都會存在這個問題,即在層上打開層,后打開的層會被之前的層擋住,因為它們的z-index都是相同的。想要日期輸入面板不被后面的“模式對話框”擋住,只能是將它的z-index設得更大點,但是單純的css修改又沒有效果,因為這個日期輸入面板是動態生成的,伴隨著里面的css,所以你預先設置它的樣式是沒有用的,除非你修改控件的源代碼。

  后來在網上查到了一個資料,其實CalendarExtender控件有幾個客戶端事件可以用,其中有一個OnClieckShown,是在日期輸入面板打開后觸發的,于是我們可以從這里下手,通過腳本來設置z-index的值。下面是代碼。

復制代碼 代碼如下:


<script type="text/javascript">
// Ensure the calendar panel was shown on the top level.
function calendarShown(sender, args) { sender._popupBehavior._element.style.zIndex = 1000005; }
</script>


  原本ModelPopupExtender的z-index值就已經很高了,這恐怕是控件的設計者擔心它會被其它層擋住的原因吧。我們將日期選擇面板的z-index值再設高一點,然后在控件中添加OnClientShown="calendarShown",保存后重新查看頁面。

完美解決在ModalPopupExtender中使用CalendarExtender時被層遮擋的問題

一切搞定!看來CalendarExtender控件提供的幾個腳本事件還是很有用的,讀者可以自己去研究下其它幾個腳本事件的用途。還有一個需要注意的地方,CalendarExtender控件雖然提供了一個非常棒的日期輸入功能,但是它本身并不對目標控件中的值進行驗證。例如那個文本框,用戶是可以手動填寫內容的,這時CalendarExtender并不對其中的值進行校驗,除非你將文本框設置為只讀,這時又會有一個問題,那就是用戶如何清除里面的值呢?看來還需要自己寫代碼驗證一下文本框里的值。結合上面給出的代碼,我們可以在給文本框添加一個客戶端onblur事件,當它失去焦點的時候,驗證其中的值。下面是用來進行驗證的js代碼。

復制代碼 代碼如下:


function CheckDate(Inobj) {
Inobj.value = trim(Inobj.value);
if (Inobj.value != "") {
var reg = /^/d{8}$/;
if (Inobj.value.match(reg) != null) {
Inobj.value = Inobj.value.substring(0, 4) + "-" + Inobj.value.substring(4, 6) + "-" + Inobj.value.substring(6, 8);
}
reg = /^([1-2]/d{3})-(([1][0-2])|(0?[1-9]))-(([3][0-1])|([1-2][0-9])|(0?[1-9]))$/;
if (Inobj.value.match(reg) == null) {
alert("輸入日期的格式不正確!");
Inobj.value = "";
Inobj.focus();
}
}
}

//移除字符串中的空格
function trim(s) {
var s2="";
for(i=0;i<s.length;i++) {
if(s.charAt(i)!=" ") s2=s2+s.charAt(i);
}
return s2;
}


然后在文本框中添加onblur="CheckDate(this);"。這樣,當用戶輸入非法值后,程序提示用戶然后清空其中的值。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美精品在线第一页| 久久av中文字幕| 国产精品成人av在线| 91色琪琪电影亚洲精品久久| 欧美激情成人在线视频| 91久久精品国产91久久性色| 国产精品极品美女在线观看免费| 欧美电影在线观看网站| 色播久久人人爽人人爽人人片视av| 国产午夜精品视频免费不卡69堂| 久久久亚洲国产天美传媒修理工| 久久久亚洲福利精品午夜| 国产精品18久久久久久麻辣| 亚洲理论片在线观看| 国产精品99久久久久久久久久久久| 日韩欧美中文字幕在线播放| 国产精品香蕉av| 色香阁99久久精品久久久| 亚洲第一区中文99精品| 亚洲人成电影在线播放| 在线观看日韩欧美| 91精品国产99| 热久久视久久精品18亚洲精品| 26uuu国产精品视频| 亚洲a中文字幕| 成人a在线观看| 欧美精品国产精品日韩精品| 欧美日韩亚洲视频| 亚洲欧美精品中文字幕在线| 亚洲高清不卡av| 亚洲v日韩v综合v精品v| 日本在线观看天堂男亚洲| 日韩精品黄色网| 亚洲伊人成综合成人网| 国产精品第一区| 中文字幕亚洲图片| 中文字幕亚洲欧美在线| 国产99久久精品一区二区永久免费| 国产不卡av在线| 欧美日韩中国免费专区在线看| 亚洲精品美女久久久久| 一区二区三区视频观看| 国产精品视频男人的天堂| 少妇高潮久久77777| 26uuu另类亚洲欧美日本一| 欧美激情第一页xxx| 最近2019中文字幕在线高清| 国产成人综合精品| 日韩av网站电影| 91精品国产91久久久久久最新| 国产成人在线播放| 久久精彩免费视频| 亚洲国产精品999| 国产精品视频久| 亚洲视频在线免费看| 亚洲第一精品福利| 亚洲精品免费av| 中文字幕成人在线| 亚洲的天堂在线中文字幕| 96sao精品视频在线观看| 97视频在线观看网址| 色多多国产成人永久免费网站| 国产成人精品视| 欧美大奶子在线| 成人字幕网zmw| 456亚洲影院| 国产日韩欧美日韩大片| 久久久久国产精品免费| 欧美国产欧美亚洲国产日韩mv天天看完整| 日韩视频亚洲视频| 亚洲欧美制服丝袜| 亚洲国产精品美女| 亚洲免费伊人电影在线观看av| 国产成人一区二区三区小说| 亚洲网站视频福利| 亚洲一二三在线| 亚洲最大成人网色| 日韩国产一区三区| 国产精品视频一区国模私拍| 亚洲石原莉奈一区二区在线观看| 亚洲精品日韩欧美| 亚洲精品乱码久久久久久金桔影视| 精品国产91乱高清在线观看| 91视频国产一区| 美女视频久久黄| 欧美日韩激情视频| 黑人精品xxx一区一二区| 欧美精品一本久久男人的天堂| 国产女同一区二区| 午夜精品久久久久久久99热浪潮| 91青草视频久久| 大伊人狠狠躁夜夜躁av一区| 97视频在线观看成人| 日韩中文字幕不卡视频| 精品免费在线观看| 久久夜色精品国产亚洲aⅴ| 久久精品成人欧美大片| 中文字幕不卡在线视频极品| 第一福利永久视频精品| 欧美性20hd另类| 久久人人爽亚洲精品天堂| 欧美激情欧美激情在线五月| 欧美高清电影在线看| 在线视频免费一区二区| 亚洲一区免费网站| 日韩av影院在线观看| 欧美午夜视频一区二区| 亚洲va久久久噜噜噜| 欧美日韩一区二区免费在线观看| 成人高清视频观看www| 国产91色在线|| 欧美极品第一页| 久久中国妇女中文字幕| www欧美日韩| 欧美日韩国产999| 亚洲va码欧洲m码| 中文字幕精品一区久久久久| 精品国产一区二区三区久久狼5月| 成人www视频在线观看| 精品国产乱码久久久久久虫虫漫画| 一本色道久久综合亚洲精品小说| 亚洲精品动漫久久久久| 国产成人综合精品在线| 伊人久久精品视频| 欧美另类交人妖| 成人在线小视频| 亚洲精品电影网| 97在线观看免费| 91精品久久久久久久久久| 亚洲精品永久免费精品| 久久av红桃一区二区小说| 在线午夜精品自拍| 欧美亚洲免费电影| 日韩精品在线看| 欧美在线日韩在线| 亚洲天堂av网| 欧美久久精品午夜青青大伊人| 成人h视频在线观看播放| 色综合天天综合网国产成人网| 国产成人福利视频| 成人欧美一区二区三区在线湿哒哒| 亚洲欧美国产视频| 亚洲毛片在线观看| 日韩免费观看高清| 色噜噜久久综合伊人一本| 欧美日韩高清在线观看| 91在线网站视频| 国产精品久久久久91| 国产精品亚洲视频在线观看| 精品欧美激情精品一区| 国产日韩中文在线| 日本不卡免费高清视频| 久久男人资源视频| 91久久久在线| 综合网日日天干夜夜久久| 欧美激情精品久久久久久蜜臀| 午夜精品三级视频福利| 日韩精品极品在线观看| 久久久久久久久久久国产| 在线观看日韩欧美| 国产精品久久97| 自拍偷拍免费精品| 日韩在线观看免费网站| 亚洲女人天堂成人av在线|