免费体验120秒视频_榴莲榴莲榴莲榴莲官网_2021国产麻豆剧果冻传媒入口_一二三四视频社区在线
當前位置:首頁文章首頁 IT學院 Java

提供大家一些Ajax小技巧

作者:  來源:  發布時間:2011-5-30 9:43:08  點擊:

這篇文章提供分享的是關于Ajax的一些小技巧,希望在你使用Ajax過程中碰到難題時,下面這些小貼士能助你一臂之力。

使用java script庫

Ajax的流行和巨大威力,讓我們重新審視了java script的開發,也直接促使各種庫的出現。對于普通的開發者,使用一些適合自己的java script庫不僅可以避免Ajax應用上的瀏覽器兼容等問題,也使其開發更加的穩定和高效。這里列一些我知曉的輕量級的java script庫:

  1. YUI:YAHOO出品,組件豐富強大健壯穩定,是團隊協作開發的首選。
  2. JQuery:靈活、高效,其基于CSS3 和XPath的選擇器語法引擎非常的強大和完整。
  3. Prototype:是一個非常優雅的java script庫,最經典的莫過于$符號了,DWR,JQuery都被它吸引了。在它基礎上出現了script.aculo.us。
  4. Mootools:核心語法和Prototype比較類似,但是用過之后才知道什么叫簡單輕巧和短小精悍。

編碼問題

通過XMLHttpRequest獲取的數據,默認的字符編碼是UTF-8,如果前端頁面是GB2312或者其它編碼,顯示獲取的數據就是亂碼。通過XMLHTTPRequest,POST的數據也是UTF-8編碼,如果后臺是GB2312或者其他編碼也會出現亂碼。解決方法:

  1. 統一到UTF-8。這也是國際化的必然趨勢。
  2. 輸出通過XMLHttpRequest獲取的文本文本時,在headers中增加文本聲明(直接HTML聲明沒有作用)。如:
    PHP:header('Content-Type:text/html;charset=GB2312');
    ASP:Response.Charset = "GB2312"
    JSP:response.setHeader("Charset","GB2312");
  3. WWW服務器上強制聲明。比如:apache下的配置:
    AddDefaultCharset GB2312

    這種情況主要是應對通過XMLHttpRequest訪問的文件是靜態文件,無法聲明headers的情況下。
    靜態頁面一般都會經過Apache的deflate或gzip壓縮,此時在上面情況下IE中,首次通過XMLhttpRequest獲得的數據可以正常顯示,但再獲取數據顯示時出現亂碼,這次因為再次獲取的數據來自緩存,可能由于瀏覽器解壓縮的問題導致Apache設置的默認編碼聲明丟失。由于這種情況下一般是純文本,可能還無法禁止緩存,可以設置XMLhttpRequest訪問的文本文件不壓縮來解決這個問題。
  4. 非UTF-8頁面通過XMLHttpRequest獲取的文本文本輸出前字符轉碼成unicode,或者編碼直接是UTF-8,可以正常顯示。

IE下的緩存問題

由于IE的緩存處理機制問題,每次通過XMLHttpRequest訪問動態頁面返回的總是首次訪問的內容,解決方法有:

  1. 客戶端通過添加隨機字符串解決。如:
    var url = 'http://dancewithnet.com/';
    url +=  '?temp=' + new Date().getTime();
    url +=  '?temp=' + Math.random();


  2. 在HTTP headers禁止緩存。如: 
    HTTP:
    <meta http-equiv="pragma" content="no-cache" />
    <meta http-equiv="Cache-Control" content="no-cache, must-revalidate" />
    <meta http-equiv="expires" content="Thu, 01 Jan 1970 00:00:01 GMT" />
    <meta http-equiv="expires" content="0" />
    PHP:
    header("Expires: Thu, 01 Jan 1970 00:00:01 GMT");
    header("Cache-Control: no-cache, must-revalidate");
    header("Pragma: no-cache");
    ASP:
    Response.expires=0
    Response.addHeader("pragma","no-cache")
    Response.addHeader("Cache-Control","no-cache, must-revalidate")
    JSP:
    response.addHeader("Cache-Control", "no-cache");
    response.addHeader("Expires", "Thu, 01 Jan 1970 00:00:01 GMT");

  3. 在XMLHttpRequest發送請求之前加上:
    XMLHttpRequest.setRequestHeader("If-Modified-Since","0");
    XMLHttpRequest.send(null);

    IE下的reponseXML問題

使用responseXML時,IE下只能接受.xml為后綴的XML文件,如果不能以.xml文件為結尾的,則需要如下處理:

  1. 在服務器端聲明是xml文件類型。如:
    PHP:header("Content-Type:text/xml;charset=utf-8");
    ASP:Response.ContentType = "text/xml";
    JSP:response.setHeader("ContentType","text/xml");

     
  2. 利用responseText獲取,然后封裝成XML。
  3. 在AJAX應用上,JSON和JsonML是XML非常好的替代品。

文章評論

軟件按字母排列: A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
免费体验120秒视频_榴莲榴莲榴莲榴莲官网_2021国产麻豆剧果冻传媒入口_一二三四视频社区在线
主站蜘蛛池模板: 韩国色三级伦不卡高清在线观看| 免费又黄又爽的视频| 中文字幕一区日韩精品| 国产交换俱乐部在线看| 不卡中文字幕| 日韩国产精品99久久久久久| 欧美激情视频一区二区| 亚洲性色高清完整版在线观看| 7m凹凸精品分类大全免费| 天天综合网天天综合色| 午夜影皖普通区| 日韩一卡2卡3卡4卡| 亚洲综合在线一区二区三区| 国产99在线播放| 狂野欧美激情性xxxx| 韩国免费特一级毛片| 国产日韩一区二区三区在线观看| 成人欧美一区二区三区| 免费看黄a级毛片| 最近中文字幕免费mv在线视频 | 日本边添边摸边做边爱喷水| 精品精品国产欧美在线观看| 久久99精品久久久久久| 亚洲有码转帖| 第四色最新网站| 国产高潮刺激叫喊视频| 午夜男女爽爽影院网站| 欧美成人精品第一区二区三区| 国产婷婷色一区二区三区| 亚洲处破女| 无码人妻精品一区二区三区久久| 暴力调教一区二区三区| 亚洲国产成人精品无码一区二区| 中文字幕日韩精品有码视频| 国产| 久久久久久国产精品mv| 欧美日韩精品一区二区在线视频| 中文字幕国产在线| 最新国语自产精品视频在| 女人与大拘交在线播放| 浮生陌笔趣阁免费阅读|