• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答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
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

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

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

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

    ASP.NET中UpdatePanel與jQuery同時使用所遇問題解決:今天,在.NET中使用了UpdatePanel,里面的輸入框使用了jQuery的日歷選擇器: 代碼如下:<script type=text/javascript> $(function(){ $(#ctl00_ContentPlaceHolder1_txtDateFrom).datepicker({ inl
    推薦度:
    導(dǎo)讀ASP.NET中UpdatePanel與jQuery同時使用所遇問題解決:今天,在.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,//每周從周一開始
    //區(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í)行。

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

    文檔

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

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

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 99精品人妻少妇一区二区| 日本精品视频在线观看| 国产精品麻豆入口| 精品久久人妻av中文字幕| 精品第一国产综合精品蜜芽| 国产欧美国产精品第一区| 日韩精品无码专区免费播放| 精品91自产拍在线观看| 久久精品国产99国产精品澳门 | 亚洲午夜福利精品久久| 国产精品区AV一区二区| 日本精品一区二区三区在线观看| 久久综合久久自在自线精品自| 四虎国产精品成人| 黑人巨大精品欧美一区二区| 8050免费午夜一级国产精品| 国内精品伊人久久久久| 99精品视频免费| 国产成人亚洲综合无码精品| 精品无码久久久久久午夜| 午夜不卡久久精品无码免费| 曰韩精品无码一区二区三区| 亚洲精品成人久久久| 亚洲精品国精品久久99热| 午夜国产精品无套| 亚洲午夜精品久久久久久app| 亚洲精品视频免费观看| 香港三级精品三级在线专区 | 亚洲AV午夜福利精品一区二区| 亚洲精品国产成人影院| 亚洲一区精品伊人久久伊人| 无码欧精品亚洲日韩一区夜夜嗨| 麻豆国内精品欧美在线| 欧美人与性动交α欧美精品| 亚洲av无码成人精品国产| 亚洲精品97久久中文字幕无码| 中日精品无码一本二本三本| 亚洲精品成人网站在线观看| 久久精品亚洲精品国产色婷| 国产成人A人亚洲精品无码| 国产成人精品视频播放|