ASP.NET中UpdatePanel與jQuery同時使用所遇問題解決
更新時間:2013年03月27日 17:23:02 作者:
在.NET中使用了UpdatePanel,里面的輸入框使用了jQuery的日歷選擇器,接下來介紹下兩者同時使用的一些細(xì)節(jié)及問題的解決方法,感興趣的各位可以參考下哈
今天,在.NET中使用了UpdatePanel,里面的輸入框使用了jQuery的日歷選擇器:
<script type="text/javascript">
$(function(){
$("#ctl00_ContentPlaceHolder1_txtDateFrom").datepicker({
inline: true,
dayNamesMin:["日","一","二","三","四","五","六"],//區(qū)域化周名為中文
firstDay:1,//每周從周一開始
//區(qū)域化月名為中文習(xí)慣 monthNames:["1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月"],
showMonthAfterYear:true,//月份顯示在年后面
yearSuffix:"年",//年份后綴字符
changeYear:true,
changeMonth:true,
showButtonPanel:true,//顯示按鈕面板
currentText:"今天",//當(dāng)前日期按鈕上的文本
closeText:"關(guān)閉",//關(guān)閉按鈕上的文本
dateFormat:"yy-mm-dd"
});
}
</script>
運(yùn)行之后正常:
可是,運(yùn)行之后,點(diǎn)擊"查詢",頁面局部刷新,發(fā)現(xiàn)日歷選擇器不出來了,找了很多資料,他們講:
分析1:UpdatePanel
UpdatePanel在應(yīng)用中主要用于局部刷新,避免整個頁面的Postback。
UpdatePanel實(shí)現(xiàn)局部刷新的核心在于MicrosoftAjaxWebForm.js文件,它的局部刷新過程就是將頁面提交到服務(wù)端(包 含ViewState),執(zhí)行服務(wù)端代碼后異步將在UpdatePanel內(nèi)的HTML進(jìn)行重新呈現(xiàn)。
在此過程中,頁面的其它部分并沒有狀態(tài)更改。
分析2:jQuery
jQuery可以通過簡單的代碼對 HTML元素添加各種屬性和事件句柄,我們可以在這里看到官方的文檔:
Tutorials:How jQuery Works
http://docs.jquery.com/How_jQuery_Works
在這里,我們可以得知,jQuery有個重要的事件標(biāo)記“ready”,一般 對HTML元素的效果和事件句柄都通過這個ready事件來添加,如下:
$(document).ready(function () {
$("p").text("The DOM is now loaded and can be manipulated.");
});
官方對此的說明是:ready事件會在DOM完全加載后運(yùn)行一次,OK,至此,問題的原因差不多明白了:
原因:
因?yàn)樵赨pdatePanel局部刷新之后,其中的文本框元素被重寫,而此時整個DOM樹并沒有重新加載,所以jQuery的ready事件并沒有觸 發(fā),所以文本框元素就失去了原有的特效。
解決方案:
我們可以將ready事件中執(zhí)行的代碼提取出來:
<script type="text/javascript">
function showdatepicker(){
$("#ctl00_ContentPlaceHolder1_txtDateFrom").datepicker({
inline: true,
dayNamesMin:["日","一","二","三","四","五","六"],//區(qū)域化周名為中文
firstDay:1,//每周從周一開始
//區(qū)域化月名為中文習(xí)慣 monthNames:["1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月"],
showMonthAfterYear:true,//月份顯示在年后面
yearSuffix:"年",//年份后綴字符
changeYear:true,
changeMonth:true,
showButtonPanel:true,//顯示按鈕面板
currentText:"今天",//當(dāng)前日期按鈕上的文本
closeText:"關(guān)閉",//關(guān)閉按鈕上的文本
dateFormat:"yy-mm-dd"
});
}
</script>
在jQuery中也放入這個函數(shù):
<script type="text/javascript">
$(function(){
showdatepicker();
});
</script>
然后通過捕獲ScriptManager的EndRequest事件,在每次 UpdatePanel局部刷新之后執(zhí)行一次jQuery初始化代碼,如下所示:
<script type="text/javascript">
function load(){
Sys.WebForms.PageRequestManager.getInstance().add_endRequest(EndRequestHandler);
}
function EndRequestHandler() {
showdatepicker();
}
</script>
最后,再在<body>中加上load()函數(shù),即:
<body onload="load()">
這樣,即便UpdatePanel局部刷新,jQuery代碼也能執(zhí)行。
復(fù)制代碼 代碼如下:
<script type="text/javascript">
$(function(){
$("#ctl00_ContentPlaceHolder1_txtDateFrom").datepicker({
inline: true,
dayNamesMin:["日","一","二","三","四","五","六"],//區(qū)域化周名為中文
firstDay:1,//每周從周一開始
//區(qū)域化月名為中文習(xí)慣 monthNames:["1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月"],
showMonthAfterYear:true,//月份顯示在年后面
yearSuffix:"年",//年份后綴字符
changeYear:true,
changeMonth:true,
showButtonPanel:true,//顯示按鈕面板
currentText:"今天",//當(dāng)前日期按鈕上的文本
closeText:"關(guān)閉",//關(guān)閉按鈕上的文本
dateFormat:"yy-mm-dd"
});
}
</script>
運(yùn)行之后正常:

可是,運(yùn)行之后,點(diǎn)擊"查詢",頁面局部刷新,發(fā)現(xiàn)日歷選擇器不出來了,找了很多資料,他們講:
分析1:UpdatePanel
UpdatePanel在應(yīng)用中主要用于局部刷新,避免整個頁面的Postback。
UpdatePanel實(shí)現(xiàn)局部刷新的核心在于MicrosoftAjaxWebForm.js文件,它的局部刷新過程就是將頁面提交到服務(wù)端(包 含ViewState),執(zhí)行服務(wù)端代碼后異步將在UpdatePanel內(nèi)的HTML進(jìn)行重新呈現(xiàn)。
在此過程中,頁面的其它部分并沒有狀態(tài)更改。
分析2:jQuery
jQuery可以通過簡單的代碼對 HTML元素添加各種屬性和事件句柄,我們可以在這里看到官方的文檔:
Tutorials:How jQuery Works
http://docs.jquery.com/How_jQuery_Works
在這里,我們可以得知,jQuery有個重要的事件標(biāo)記“ready”,一般 對HTML元素的效果和事件句柄都通過這個ready事件來添加,如下:
$(document).ready(function () {
$("p").text("The DOM is now loaded and can be manipulated.");
});
官方對此的說明是:ready事件會在DOM完全加載后運(yùn)行一次,OK,至此,問題的原因差不多明白了:
原因:
因?yàn)樵赨pdatePanel局部刷新之后,其中的文本框元素被重寫,而此時整個DOM樹并沒有重新加載,所以jQuery的ready事件并沒有觸 發(fā),所以文本框元素就失去了原有的特效。
解決方案:
我們可以將ready事件中執(zhí)行的代碼提取出來:
復(fù)制代碼 代碼如下:
<script type="text/javascript">
function showdatepicker(){
$("#ctl00_ContentPlaceHolder1_txtDateFrom").datepicker({
inline: true,
dayNamesMin:["日","一","二","三","四","五","六"],//區(qū)域化周名為中文
firstDay:1,//每周從周一開始
//區(qū)域化月名為中文習(xí)慣 monthNames:["1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月"],
showMonthAfterYear:true,//月份顯示在年后面
yearSuffix:"年",//年份后綴字符
changeYear:true,
changeMonth:true,
showButtonPanel:true,//顯示按鈕面板
currentText:"今天",//當(dāng)前日期按鈕上的文本
closeText:"關(guān)閉",//關(guān)閉按鈕上的文本
dateFormat:"yy-mm-dd"
});
}
</script>
在jQuery中也放入這個函數(shù):
復(fù)制代碼 代碼如下:
<script type="text/javascript">
$(function(){
showdatepicker();
});
</script>
然后通過捕獲ScriptManager的EndRequest事件,在每次 UpdatePanel局部刷新之后執(zhí)行一次jQuery初始化代碼,如下所示:
復(fù)制代碼 代碼如下:
<script type="text/javascript">
function load(){
Sys.WebForms.PageRequestManager.getInstance().add_endRequest(EndRequestHandler);
}
function EndRequestHandler() {
showdatepicker();
}
</script>
最后,再在<body>中加上load()函數(shù),即:
復(fù)制代碼 代碼如下:
<body onload="load()">
這樣,即便UpdatePanel局部刷新,jQuery代碼也能執(zhí)行。
您可能感興趣的文章:
- asp.net ext treepanel 動態(tài)加載XML的實(shí)現(xiàn)方法
- asp.net UpdatePanel的簡單用法
- ASP.Net PlaceHolder、Panel等控件未實(shí)現(xiàn)INamingContainer,導(dǎo)致FindControl無效
- asp.net UpdatePanel實(shí)現(xiàn)無刷新上傳圖片
- asp.net Coolite TablePanel使用
- asp.net通過Ajax UpdatePanel回傳后滾動條位置變更解決方法
- asp.net updatepanel 導(dǎo)致JS不能加載,而無法使用的解決方法
- asp.net頁面觸發(fā)事件panel滾動條高度不變的實(shí)現(xiàn)方法
- ASP.NET中 Panel 控件的使用方法
相關(guān)文章
數(shù)據(jù)庫 數(shù)據(jù)類型float到C#類型decimal, float數(shù)據(jù)類型轉(zhuǎn)化無效
數(shù)據(jù)庫 數(shù)據(jù)類型float到C#類型decimal, float數(shù)據(jù)類型轉(zhuǎn)化無效的解決方法2009-07-07.NET下文本相似度算法余弦定理和SimHash淺析及應(yīng)用實(shí)例分析
這篇文章主要介紹了.NET下文本相似度算法余弦定理和SimHash淺析及應(yīng)用,實(shí)例形式詳細(xì)講述了相似度算法余弦定理和SimHash的原理與用法,需要的朋友可以參考下2015-01-01Asp.net SignalR 讓實(shí)時通訊變得如此簡單
下面小編就為大家分享一篇Asp.net SignalR 讓實(shí)時通訊變得如此簡單,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01ASP.NET?MVC實(shí)現(xiàn)區(qū)域路由
這篇文章介紹了ASP.NET?MVC實(shí)現(xiàn)區(qū)域路由的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03asp.net網(wǎng)站的404錯誤頁面的正確設(shè)置方法
asp.net網(wǎng)站的404錯誤頁面的正確設(shè)置方法,需要的朋友可以參考下。2010-05-05ASP.NET Core Middleware的實(shí)現(xiàn)方法詳解
中間件是組裝到應(yīng)用程序管道中以處理請求和響應(yīng)的軟件。下面這篇文章主要給大家介紹了關(guān)于ASP.NET Core Middleware實(shí)現(xiàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2019-01-01.NET的file文件上傳控件使用方法 修改web.config文件上傳大文件
這篇文章主要介紹了.NET修改web.config文件上傳大文件的方法,大家參考使用吧2014-01-01