最新文章專題視頻專題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

ASP.NET中UpdatePanel與jQuery同時(shí)使用所遇問(wèn)題解決

來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:41:29
文檔

ASP.NET中UpdatePanel與jQuery同時(shí)使用所遇問(wèn)題解決

ASP.NET中UpdatePanel與jQuery同時(shí)使用所遇問(wèn)題解決:今天,在.NET中使用了UpdatePanel,里面的輸入框使用了jQuery的日歷選擇器: 代碼如下:<script type=text/javascript> $(function(){ $(#ctl00_ContentPlaceHolder1_txtDateFrom).datepicker({ inl
推薦度:
導(dǎo)讀ASP.NET中UpdatePanel與jQuery同時(shí)使用所遇問(wèn)題解決:今天,在.NET中使用了UpdatePanel,里面的輸入框使用了jQuery的日歷選擇器: 代碼如下:<script type=text/javascript> $(function(){ $(#ctl00_ContentPlaceHolder1_txtDateFrom).datepicker({ inl

今天,在.NET中使用了UpdatePanel,里面的輸入框使用了jQuery的日歷選擇器:
代碼如下:

<script type="text/javascript">
$(function(){
$("#ctl00_ContentPlaceHolder1_txtDateFrom").datepicker({
inline: true,
dayNamesMin:["日","一","二","三","四","五","六"],//區(qū)域化周名為中文
firstDay:1,//每周從周一開(kāi)始
//區(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)擊"查詢",頁(yè)面局部刷新,發(fā)現(xiàn)日歷選擇器不出來(lái)了,找了很多資料,他們講:
分析1:UpdatePanel
UpdatePanel在應(yīng)用中主要用于局部刷新,避免整個(gè)頁(yè)面的Postback。
UpdatePanel實(shí)現(xiàn)局部刷新的核心在于MicrosoftAjaxWebForm.js文件,它的局部刷新過(guò)程就是將頁(yè)面提交到服務(wù)端(包 含ViewState),執(zhí)行服務(wù)端代碼后異步將在UpdatePanel內(nèi)的HTML進(jìn)行重新呈現(xiàn)。
在此過(guò)程中,頁(yè)面的其它部分并沒(méi)有狀態(tài)更改。
分析2:jQuery
jQuery可以通過(guò)簡(jiǎn)單的代碼對(duì) HTML元素添加各種屬性和事件句柄,我們可以在這里看到官方的文檔:
Tutorials:How jQuery Works
http://docs.jquery.com/How_jQuery_Works
在這里,我們可以得知,jQuery有個(gè)重要的事件標(biāo)記“ready”,一般 對(duì)HTML元素的效果和事件句柄都通過(guò)這個(gè)ready事件來(lái)添加,如下:
$(document).ready(function () {
$("p").text("The DOM is now loaded and can be manipulated.");
});
官方對(duì)此的說(shuō)明是:ready事件會(huì)在DOM完全加載后運(yùn)行一次,OK,至此,問(wèn)題的原因差不多明白了:
原因:
因?yàn)樵赨pdatePanel局部刷新之后,其中的文本框元素被重寫(xiě),而此時(shí)整個(gè)DOM樹(shù)并沒(méi)有重新加載,所以jQuery的ready事件并沒(méi)有觸 發(fā),所以文本框元素就失去了原有的特效。
解決方案:
我們可以將ready事件中執(zhí)行的代碼提取出來(lái):
代碼如下:

<script type="text/javascript">
function showdatepicker(){
$("#ctl00_ContentPlaceHolder1_txtDateFrom").datepicker({
inline: true,
dayNamesMin:["日","一","二","三","四","五","六"],//區(qū)域化周名為中文
firstDay:1,//每周從周一開(kāi)始
//區(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中也放入這個(gè)函數(shù):
代碼如下:

<script type="text/javascript">
$(function(){
showdatepicker();
});
</script>

然后通過(guò)捕獲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í)行。

聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

ASP.NET中UpdatePanel與jQuery同時(shí)使用所遇問(wèn)題解決

ASP.NET中UpdatePanel與jQuery同時(shí)使用所遇問(wèn)題解決:今天,在.NET中使用了UpdatePanel,里面的輸入框使用了jQuery的日歷選擇器: 代碼如下:<script type=text/javascript> $(function(){ $(#ctl00_ContentPlaceHolder1_txtDateFrom).datepicker({ inl
推薦度:
  • 熱門(mén)焦點(diǎn)

最新推薦

猜你喜歡

熱門(mén)推薦

專題
Top