TargetControlID:日期輸入的目標控件ID,一般來說都都是一個文本 " /> gogo免费在线观看,欧美丰满白嫩bbxx,久草在线在线精品观看

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

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

大家可以去官方網(wǎng)站查看demo,ModalPopupExtender控件用來在網(wǎng)頁中實現(xiàn)類似于模式對話框的效果,而CalendarExterder控件提供日期輸入,它有幾個很重要的屬性:

TargetControlID:日期輸入的目標控件ID,一般來說都都是一個文本框。
Format:日期格式,如yyyy-MM-dd。
PopupButtonID:用戶打開日期選擇面板的控件ID,如按鈕,圖片等。
PopupPosition:設(shè)置日期選擇面板打開的位置,這個是相對于TargetControlID所在控件的位置的。有幾個可選的值:BottomLeft,BottomRight,Left,Right,TopLeft,TopRight。
  一般來說我們只需要設(shè)置這幾個屬性就可以滿足應(yīng)用了,除非你想自定義日期選擇面板的顯示樣式,這時你需要自己給定CssClass。這里是一個例子。
復(fù)制代碼 代碼如下:
<ASP:TextBox ID="tbBeginTime" runat="server" CssClass="singleText" MaxLength="10" Width="90"></ASP:TextBox>
<ASP:Image ID="imgBeginTime" ImageUrl="/upload/2009-11/20091124203311125.png" runat="server" />
<ajaxToolkit:CalendarExtender ID="CalendarExtenderBeginTime" Format="yyyy-MM-dd" TargetControlID="tbBeginTime" PopupButtonID="imgBeginTime" runat="server">
</ajaxToolkit:CalendarExtender>

  網(wǎng)上有人說這個控件打開的日期選擇面板會被下拉列表擋住,好像在早期的版本中會存在這個問題,現(xiàn)在新的版本已經(jīng)修正了這個bug。我所遇到的問題是在ModelPopupExtender控件中使用CalendarExtender,日期選擇面板會被后面的ModelPopupExtender擋住。有關(guān)ModelPopupExtender的使用讀者可以看看官方網(wǎng)站的例子,很簡單,這里我就不多說了。看一下問題的截圖。
2009-11-24 9-52-45看到了吧!CalendarExtender彈出的日期選擇面板被后面的ModelPopupExtender擋住了。我在Google上搜了一些資料,大多都是講怎么重新設(shè)置CalendarExtender控件的樣式,指定層的z-inde屬性等,但我嘗試過都失敗了,其中有人說在IE6下測試是可以的,不過我沒有驗證過,因為我現(xiàn)在也找不到裝有IE6的機器了,沒有環(huán)境,自然測不了。

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

  后來在網(wǎng)上查到了一個資料,其實CalendarExtender控件有幾個客戶端事件可以用,其中有一個OnClieckShown,是在日期輸入面板打開后觸發(fā)的,于是我們可以從這里下手,通過腳本來設(shè)置z-index的值。下面是代碼。
復(fù)制代碼 代碼如下:
<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值就已經(jīng)很高了,這恐怕是控件的設(shè)計者擔心它會被其它層擋住的原因吧。我們將日期選擇面板的z-index值再設(shè)高一點,然后在控件中添加OnClientShown="calendarShown",保存后重新查看頁面。
2009-11-24 9-54-36一切搞定!看來CalendarExtender控件提供的幾個腳本事件還是很有用的,讀者可以自己去研究下其它幾個腳本事件的用途。還有一個需要注意的地方,CalendarExtender控件雖然提供了一個非常棒的日期輸入功能,但是它本身并不對目標控件中的值進行驗證。例如那個文本框,用戶是可以手動填寫內(nèi)容的,這時CalendarExtender并不對其中的值進行校驗,除非你將文本框設(shè)置為只讀,這時又會有一個問題,那就是用戶如何清除里面的值呢?看來還需要自己寫代碼驗證一下文本框里的值。結(jié)合上面給出的代碼,我們可以在給文本框添加一個客戶端onblur事件,當它失去焦點的時候,驗證其中的值。下面是用來進行驗證的js代碼。
復(fù)制代碼 代碼如下:
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);"。這樣,當用戶輸入非法值后,程序提示用戶然后清空其中的值。

AspNet技術(shù)完美解決在ModalPopupExtender中使用CalendarExtender時被層遮擋的問題,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲AV永久无码精品老司机蜜桃 | 青青青草国产 | 亚洲1卡二卡3卡4卡新区在线 | 亚洲乱亚洲乱妇13p 亚洲乱色视频在线观看 | 乱叫抽搐流白浆免费视频 | 拔萝卜电视剧高清免费 | 久久精品国产欧美日韩99热 | 一级黄色香蕉视频 | 两个奶被男人揉了一个晚上 | 亚洲欧美日韩在线码不卡 | 亚洲一区免费香蕉在线 | 久9青青cao精品视频在线 | 亚洲 日韩 在线 国产 精品 | 海角国精产品一区一区三区糖心 | 男女久久久国产一区二区三区 | 日韩欧美 亚洲视频 | 三级黄.色| 伊人精品影院一本到综合 | 麻豆三级电影 | 最新精品国产 | 天天影视网网色色欲 | 久久综合色超碰人人 | 人禽l交视频在线播放 视频 | 在线观看亚洲AV无码每日更新 | 365电影成人亚洲网在线观看 | swag合集120部 | 免费女性裸身照无遮挡网站 | 被肉日常np快穿高h 被肉日常np高h | 国精产品一区一区三区有 | 精品无码久久久久久国产百度 | 成人无码精品一区二区在线观看 | 亚洲国产精品久久精品成人网站 | 精品蜜臀AV在线天堂 | 涩涩免费视频软件 | 学校捏奶揉下面污文h | 久久精品亚洲AV高清网站性色 | 韩国无遮羞禁动漫在线观看96 | 亚洲高清视频免费 | 日本少妇无码精品12P | 国产亚洲中文字幕视频 | 爆乳啪啪无码成人二区亚洲欧美 |