日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

【从0到1学Web前端】javascript中的ajax对象(一)

發布時間:2025/4/16 javascript 16 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【从0到1学Web前端】javascript中的ajax对象(一) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
【從0到1學Web前端】javascript中的ajax對象(一)

如今最流行的獲取后端的(瀏覽器從server)數據的方式就是通過Ajax了吧。今天就來具體的來學習下這個知識吧。假設使用ajax來訪問后段的數據,瀏覽器和瀏覽器端的js做了那些工作呢?我做了一個圖,請大家看一下:

1.原生js的Ajax請求的方式

由上面的圖我們大致的知道了ajax訪問后端數據的一個過程。最重要的就是檢測瀏覽器,創建XMLHttpRequest對象的過程:
代碼例如以下:

/*推斷是否支持XMLHttpRequest*/ function createXHR() {if (typeof XMLHttpRequest != "undefined") {return new XMLHttpRequest();}else if (typeof ActiveXobject != "undefined") {if (typeof arguments.callee.activeXString != 'string') {var versions = ["MSXML2.XMLHttp.6.0", "MSXML2.XMLHttp.3.0", "MSXML2.XMLHttp"], i, len;for (i = 0, len = versions.length; i < len; i++) {try {new ActiveXObject(versions[i]);arguments.callee.activeXString = versions[i];break;}catch (ex) {console.log(ex);}}}return new ActiveXObject(arguments.callee.activeXString());}else {throw new Error('no XHR')} }

此處各自是依據瀏覽器是否支持XMLHttpRequest對象來推斷是否是IE還是非IE,然后來創建響應的對象。

當XHR對象open()的時候。此時并沒有向Webserver發送HTTP請求。而是當send()的時候,XHR對象才向Webserver發送請求。

xhr.send('');

這里有一個非常重要的地方。就是send的參數為null。

send()方法接收一個參數,須要作為請求主體發送的數據。假設不須要作為請求主體發送數據,則必須傳入null,由于這個參數對于某些瀏覽器是必須的。

當瀏覽器接收到Webserver的響應后,會開始填充XHR對象的屬性,基本的例如以下:

  • responseText作為響應的主體被返回的文本
  • responseXML假設響應的內容類型為text/xml或者application/xml這個屬性中將包括著響應數據的XML DOM文檔
  • status響應的HTTP狀態
  • statusTextHTTP狀態的說明

    一般通過XHR.status屬性值為200表示成功的標志。

    此時能夠獲取responseText和responseXML的值。當XHR.status==304(響應是有效的)的時候,說明文件沒有被改動,能夠直接使用瀏覽器緩存的版本號。

檢測的代碼例如以下:

if (xhr.status >= 200 && xhr.status <= 300 || xhr.status == 304) {console.log(xhr.responseText);}else {console.log(xhr.responseText);}

不要依賴responseText。由于在跨瀏覽器處理的時候這個屬性獲取的值是不可靠的。

上面的代碼在同步發送請求驗證和獲取返會的數據是沒有不論什么問題的。可是當我們發送異步請求的時候確實會出現故障,由于我們不知道服務端的Response在什么時候反回。那么我們該怎么辦呢?

事實上在ajax在向Webserver發送請求的時候,會有一個readyState屬性來檢測XHR對象的請求/響應過程的當前活動階段,值的列表例如以下:

  • 0未初始化。

    尚未調用open()方法

  • 1啟動。已經調用open()方法。可是尚未調用send()方法
  • 2發送。

    已經調用send()方法。可是還沒有接收到響應。

  • 3接收。已經接收到部分的響應數據。

  • 4完畢。已經接收到所有的響應數據。并且已經在client能夠使用了。

    每當XHR.readyState的屬性值發生變化,都會觸發一次onreadystatechange事件。通常我們僅僅對XHR.readyState==4的時候感興趣(這時數據已經所有就緒)。

必須在調用open()之前指定onreadystatechange事件處理程序才干夠保證夸瀏覽器的兼容性。

實例代碼例如以下:

var xhr = new createXHR();xhr.onreadystatechange = function () {if (xhr.readyState == 4) {if (xhr.status >= 200 && xhr.status <= 300 || xhr.status == 304) {console.log(xhr.responseText);//console.log(xhr.)//document.createElement()creatNode('script');creatNode('img');}else {console.log(xhr.responseText);}}}xhr.open('GET', 'test.js', true);xhr.send('');

2.jQuery發送Ajax的方式

參考jquery的文檔,使用jquery來發送ajax請求比原生的js簡單非常多。例如以下代碼:

2.1GET方式

$.ajax({type: "GET",url: "test.js",dataType: "script" });

2.2POST方式

$.ajax({type: "POST",url: "some.php",data: "name=John&location=Boston",success: function(msg){alert( "Data Saved: " + msg );} });

這里也僅僅是簡單的實例,假設想要具體的了解jQuery中ajax的使用。能夠參考Jquery的官方文檔。


中文文檔(點擊轉到)
英文文檔(點擊轉到)

posted on 2017-06-11 21:06 mthoutai 閱讀(...) 評論(...) 編輯 收藏

轉載于:https://www.cnblogs.com/mthoutai/p/6986368.html

總結

以上是生活随笔為你收集整理的【从0到1学Web前端】javascript中的ajax对象(一)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 精品国产传媒 | 91av色| 先锋影音久久 | 欧美一级淫片免费视频魅影视频 | 久色视频在线观看 | 日本妇女毛茸茸 | 国产亚洲高清视频 | 国产免费无遮挡吸奶头视频 | 鸥美一级片 | 欧美日韩国产中文 | 白丝校花扒腿让我c | 色综合久久久久久 | 一区二区三区四区免费 | 午夜精品久久久久 | 精品免费国产一区二区三区四区 | 中文国产在线观看 | 日本黄色免费看 | 热99视频 | 国产在线观看av | av久操| 熟女少妇精品一区二区 | 99久久99久久久精品棕色圆 | 91手机在线观看 | 女人18毛片毛片毛片毛片区二 | 久久人爽 | 欧美日韩一区二区三区免费 | 亚洲在线播放 | 国产精品扒开腿做爽爽爽a片唱戏 | 一直草 | 在线观看免费黄色小视频 | 久草资源福利 | 日韩免费片 | 午夜黄色录像 | 久久日精品 | 亚洲熟女乱综合一区二区三区 | 一本大道av | 蜜桃传媒一区二区亚洲av | 伊人情人综合 | 亚州av影院 | 欧美视频在线播放 | 激情久久婷婷 | 五月天婷婷久久 | 亚洲女人网 | 自拍av在线 | 日韩欧美a级片 | 天天操操操操 | 亚洲一区二区自偷自拍 | 天天av网 | 99视频在线看 | 亚洲色欲色欲www | 嫩草天堂 | 毛茸茸日本熟妇高潮 | 日韩免费视频一区二区 | 欧美成人免费看 | 久久久一二三 | 欧美中日韩在线 | 欧洲熟妇的性久久久久久 | 亚洲成人黄色在线 | www黄色片 | 这里只有精品视频在线观看 | 剧情av在线| 九九自拍 | 精品在线免费视频 | 76少妇精品导航 | aaa国产 | 欧美精品久久久久久久久 | 日韩美女三级 | 在线欧美色 | 国产成人a亚洲精品 | 38激情| 日韩国产二区 | 东北老女人av | 免费在线一区二区 | a猛片| 在线免费观看视频黄 | 国产l精品国产亚洲区久久 午夜青青草 | 午夜激情免费 | 精品美女久久久 | 福利视频不卡 | 国产精品久久久久久久久久久久久 | 亚洲激情五月 | 亚洲天天 | 久久久情 | 精品日韩欧美 | 久久久久在线视频 | 亚洲自拍p| 噜噜色网 | 久草热在线视频 | 7mav视频| 亚洲美女偷拍 | jjzz在线| 在线看国产视频 | 视频在线观看一区二区 | 手机看片福利永久 | 福利视频在线 | 日韩精品在线视频 | 亚洲97 | 欧美日韩在线视频一区二区三区 | av最新地址 |