ASP.NET中UpdatePanel與jQuery同時使用所遇問題解決

來源:互聯網
上載者:User

今天,在.NET中使用了UpdatePanel,裡面的輸入框使用了jQuery的日曆選取器: 複製代碼 代碼如下:<script type="text/javascript">
$(function(){
$("#ctl00_ContentPlaceHolder1_txtDateFrom").datepicker({
inline: true,
dayNamesMin:["日","一","二","三","四","五","六"],//地區化周名為中文
firstDay:1,//每周從周一開始
//地區化月名為中文習慣 monthNames:["1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月"],
showMonthAfterYear:true,//月份顯示在年後面
yearSuffix:"年",//年份尾碼字元
changeYear:true,
changeMonth:true,
showButtonPanel:true,//顯示按鈕面板
currentText:"今天",//當前日期按鈕上的文本
closeText:"關閉",//關閉按鈕上的文本
dateFormat:"yy-mm-dd"
});
}
</script>

運行之後正常:

可是,運行之後,點擊"查詢",頁面局部重新整理,發現日曆選取器不出來了,找了很多資料,他們講:
分析1:UpdatePanel
UpdatePanel在應用中主要用於局部重新整理,避免整個頁面的Postback。
UpdatePanel實現局部重新整理的核心在於MicrosoftAjaxWebForm.js檔案,它的局部重新整理過程就是將頁面提交到服務端(包 含ViewState),執行服務端代碼後非同步將在UpdatePanel內的HTML進行重新呈現。
在此過程中,頁面的其它部分並沒有狀態更改。
分析2:jQuery
jQuery可以通過簡單的代碼對 HTML元素添加各種屬性和事件控制代碼,我們可以在這裡看到官方的文檔:
Tutorials:How jQuery Works
http://docs.jquery.com/How_jQuery_Works
在這裡,我們可以得知,jQuery有個重要的事件標記“ready”,一般 對HTML元素的效果和事件控制代碼都通過這個ready事件來添加,如下:
$(document).ready(function () {
$("p").text("The DOM is now loaded and can be manipulated.");
});
官方對此的說明是:ready事件會在DOM完全載入後運行一次,OK,至此,問題的原因差不多明白了:
原因:
因為在UpdatePanel局部重新整理之後,其中的文字框元素被重寫,而此時整個DOM樹並沒有重新載入,所以jQuery的ready事件並沒有觸 發,所以文字框元素就失去了原有的特效。
解決方案
我們可以將ready事件中執行的代碼提取出來: 複製代碼 代碼如下:<script type="text/javascript">
function showdatepicker(){
$("#ctl00_ContentPlaceHolder1_txtDateFrom").datepicker({
inline: true,
dayNamesMin:["日","一","二","三","四","五","六"],//地區化周名為中文
firstDay:1,//每周從周一開始
//地區化月名為中文習慣 monthNames:["1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月"],
showMonthAfterYear:true,//月份顯示在年後面
yearSuffix:"年",//年份尾碼字元
changeYear:true,
changeMonth:true,
showButtonPanel:true,//顯示按鈕面板
currentText:"今天",//當前日期按鈕上的文本
closeText:"關閉",//關閉按鈕上的文本
dateFormat:"yy-mm-dd"
});
}
</script>

在jQuery中也放入這個函數複製代碼 代碼如下:<script type="text/javascript">
$(function(){
showdatepicker();
});
</script>

然後通過捕獲ScriptManager的EndRequest事件,在每次 UpdatePanel局部重新整理之後執行一次jQuery初始化代碼,如下所示: 複製代碼 代碼如下:<script type="text/javascript">
function load(){
Sys.WebForms.PageRequestManager.getInstance().add_endRequest(EndRequestHandler);
}
function EndRequestHandler() {
showdatepicker();
}
</script>

最後,再在<body>中加上load()函數,即: 複製代碼 代碼如下:<body onload="load()">

這樣,即便UpdatePanel局部重新整理,jQuery代碼也能執行。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.