国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

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

2024-07-10 13:17:05
字體:
來源:轉載
供稿:網友
今天,在.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>


運行之后正常:

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

 
可是,運行之后,點擊"查詢",頁面局部刷新,發現日歷選擇器不出來了,找了很多資料,他們講:
分析1:UpdatePanel
UpdatePanel在應用中主要用于局部刷新,避免整個頁面的Postback。
UpdatePanel實現局部刷新的核心在于MicrosoftAjaxWebForm.js文件,它的局部刷新過程就是將頁面提交到服務端(包 含ViewState),執行服務端代碼后異步將在UpdatePanel內的HTML進行重新呈現。
在此過程中,頁面的其它部分并沒有狀態更改。
分析2:jQuery
jQuery可以通過簡單的代碼對 HTML元素添加各種屬性和事件句柄,我們可以在這里看到官方的文檔:
Tutorials: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>


這樣,即便UpdatePanel局部刷新,jQuery代碼也能執行。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 沭阳县| 永昌县| 五河县| 连江县| 百色市| 佛山市| 嘉禾县| 策勒县| 宜昌市| 太仓市| 华容县| 湘潭市| 凌云县| 苍山县| 方城县| 富宁县| 建德市| 洛隆县| 桃江县| 财经| 綦江县| 平和县| 兴和县| 彭州市| 壶关县| 沂南县| 高青县| 平江县| 明溪县| 隆昌县| 灌阳县| 浏阳市| 安福县| 菏泽市| 桃园市| 中方县| 安仁县| 宝丰县| 中方县| 永康市| 徐州市|