<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Calvin's Tech Space

    成于堅忍,毀于浮躁

       :: 首頁 :: 聯系 :: 聚合  :: 管理

    項目有時要用一些Ajax的效果,因為比較簡單,也就沒有去用什么Ajax.net之類的東西,手寫代碼也就實現了。、

    第二天,有人向我報告錯誤;說是只有第一次讀取的值正常,后面的值都不正常;我調試了一下 ,確實有這樣的問題,查出是因為AJAX緩存的問題:解決辦法有如下幾種:

          1、在服務端加 header("Cache-Control: no-cache, must-revalidate");(如php中)

      2、在ajax發送請求前加上 anyAjaxObj.setRequestHeader("If-Modified-Since","0");

      3、在ajax發送請求前加上 anyAjaxObj.setRequestHeader("Cache-Control","no-cache");

      4、在 Ajax 的 URL 參數后加上 "?fresh=" + Math.random(); //當然這里參數 fresh 可以任意取了

      5、第五種方法和第四種類似,在 URL 參數后加上 "?timestamp=" + new Date().getTime();

      6、用POST替代GET:不推薦

     

    1、加個隨機數
          xmlHttp.open("GET", "ajax.asp?now=" + new Date().getTime(), true);

    2、在要異步獲取的asp頁面中寫一段禁止緩存的代碼:
          Response.Buffer =True
          Response.ExpiresAbsolute =Now() - 1
          Response.Expires=0
          Response.CacheControl="no-cache"

    3、在ajax發送請求前加上xmlHTTP.setRequestHeader("If-Modified-Since","0");可以禁止緩存
          xmlHTTP.open("get", URL, true); 
          xmlHTTP.onreadystatechange = callHTML; 
          xmlHTTP.setRequestHeader("If-Modified-Since","0"); 
          xmlHTTP.send();

    另一個作者寫到:

    AJAX的緩存是由瀏覽器維持的,對于發向服務器的某個url,ajax僅在第一次請求時與服務器交互信息,之后的請求中,ajax不再向服務器提交請求,而是直接從緩存中提取數據。

    有些情況下,我們需要每一次都從服務器得到更新后數據。思路是讓每次請求的url都不同,而又不影響正常應用:在url之后加入隨機內容。
    e.g.
    url=url+"&"+Math.random();

    Key points:
    1.每次請求的url都不一樣(ajax的緩存便不起作用)
    2.不影響正常應用(最基本的)

    ----------------
    方法二:(未經證實)
    在JSP中禁止緩存
    response.addHeader("Cache-Control", "no-cache");
    response.addHeader("Expires", "Thu, 01 Jan 1970 00:00:01 GMT"); 

    HTTP:
    <META HTTP-EQUIV="pragma" CONTENT="no-cache">
    <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate">
    <META HTTP-EQUIV="expires" CONTENT="Wed, 26 Feb 1997 08:21:57 GMT">
    <META HTTP-EQUIV="expires" CONTENT="0">

    另一個作者寫到:

    我們都知道,ajax能提高頁面載入的速度的主要原因是通過ajax減少了重復數據的載入,真正做到按需獲取,既然如此,我們在寫ajax程序的時候不妨送佛送到西,在客戶端再做一次緩存,進一步提高數據載入速度。那就是在載入數據的同時將數據緩存在瀏覽器內存中,一旦數據被載入,只要頁面未刷新,該數據就永遠的緩存在內存中,當用戶再次查看該數據時,則不需要從服務器上去獲取數據,極大的降低了服務器的負載和提高了用戶的體驗。

    參考:

    http://www.cnblogs.com/yslow/archive/2009/08/28/1555777.html

    http://www.cnblogs.com/yslow/archive/2009/08/28/1555856.html


    http://www.cnblogs.com/quange/archive/2009/07/24/1529958.html

    posted on 2010-11-15 18:40 calvin 閱讀(291) 評論(0)  編輯  收藏 所屬分類: Network
    主站蜘蛛池模板: 国产精品无码永久免费888| 黄色网址大全免费| 99视频在线看观免费| 亚洲国产精品无码专区| 国内精品久久久久影院免费| 亚洲中文字幕无码中文字在线| h片在线播放免费高清| 久久亚洲国产精品五月天婷| 中文字幕在线观看免费| 亚洲精品成人片在线播放| 一级毛片免费播放| 亚洲AV成人无码天堂| 日本一道本高清免费| 窝窝影视午夜看片免费| 国产亚洲AV手机在线观看| 日本免费一区二区久久人人澡| 久久久久亚洲Av片无码v| 中文字幕成人免费视频| 亚洲人成网站18禁止久久影院| 黄网址在线永久免费观看| 免费无码又爽又黄又刺激网站| 国产精品亚洲A∨天堂不卡| 91精品国产免费| 亚洲七久久之综合七久久| 亚洲AV成人潮喷综合网| 国产亚洲精品免费视频播放| 亚洲第一网站免费视频| 日本免费一二区在线电影| 中文字幕在线免费视频| 亚洲国产精品日韩在线| 免费看一级做a爰片久久| 国内精品免费久久影院| 亚洲人成影院午夜网站| 亚洲国产av一区二区三区| 免费国产黄网站在线观看可以下载 | 极品色天使在线婷婷天堂亚洲 | 99爱在线精品视频免费观看9| 一本色道久久综合亚洲精品蜜桃冫| 国产美女做a免费视频软件| 成人久久免费网站| 亚洲日本一线产区和二线|