js 實現(xiàn)ajax發(fā)送步驟過程詳解
js發(fā)送ajax發(fā)送,分步驟進(jìn)行
ajax的核心 是XMLHttpRequest,
步驟1:創(chuàng)建一個對象xmlrequest,在主流的瀏覽器都支持new ,
var xmlhttp = new XMLHttpRequest() IE瀏覽器不支持這種方法,需要再寫一個函數(shù)來創(chuàng)建
步驟2 :連接服務(wù)端
得到XMLHTTPRequest對象后,就可以調(diào)用對象的open()方法,與服務(wù)器連接,參數(shù)如下
open(method,url,async):
- method:請求方法GET或POST,
- url:服務(wù)器的地址,
- async :表示異步請求,可以不寫,默認(rèn)是True,
- xmlhttp.open("GET“,"/ajax_get/",true);
步驟3:發(fā)送請求
xmlhtto.send(null),有兼容的問題,加上null, null在js中一種數(shù)據(jù)類型,表示空,
以上3個步驟相當(dāng)于jquery的
$.ajax({
url:"/ajax_get/",
type:"GET",
success:function(){
}
)}
步驟4:接收服務(wù)器響應(yīng),
請求發(fā)出,服務(wù)端開始執(zhí)行,
XMLHttpRequest對象有一個onreadystatechange事件,
0:初始化外網(wǎng)狀態(tài),只創(chuàng)建XMLHttpRequest對象,
1:請求開始,open( )方法調(diào)用,
2:請求發(fā)送完成狀態(tài),send()方法調(diào)用,
3: 開始讀取服務(wù)器響應(yīng),
4:讀取服務(wù)器響應(yīng)結(jié)束,
onreadystatechange 事件會在狀態(tài)為1,2,3,4 時引發(fā),
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="/index/" method="post">
<p><input type="text">{{ error }}</p>
<p><input type="text">{{ error }}</p>
<p><input type="submit"></p>
</form>
<p>用戶名:<input type="text" class="user"></p>
<button onclick="send()">ajax</button>
</body>
<script>
{# 給button按鈕綁定send事件#}
function send() {
var ele = document.getElementsByClassName("user")[0];
var con = ele.valueOf;
xmlHttp=new XMLHttpRequest();
xmlHttp.open("GET","/getajax/",true);
xmlHttp.send(null);
{#監(jiān)聽服務(wù)端 #}
xmlHttp.onreadystatechange=function () {
if (xmlHttp.readyState ==4 && xmlHttp.status ==200){
alert(xmlHttp.responseText);
alert(typeof xmlHttp.responseText)
}
}
}通過XMLHttpRequest對象的readyState屬性來得到XMLHttpRequest對象的狀態(tài)。需要獲取到服務(wù)器響應(yīng)的內(nèi)容,可以通過XMLHttpRequest對象的responseText得到服務(wù)器響應(yīng)內(nèi)容。
</script>
</html>
ajax的post請求
<1>需要設(shè)置請求頭:xmlHttp.setRequestHeader(“Content-Type”, “application/x-www-form-urlencoded”);注意 :form表單會默認(rèn)這個鍵值對不設(shè)定,Web服務(wù)器會忽略請求體的內(nèi)容。
<2>在發(fā)送時可以指定請求體了:xmlHttp.send(“username=yuan&password=123”)
創(chuàng)建XMLHttpRequest對象;
調(diào)用open()方法打開與服務(wù)器的連接;
調(diào)用send()方法發(fā)送請求;
為XMLHttpRequest對象指定onreadystatechange事件函數(shù),這個函數(shù)會在
XMLHttpRequest的1、2、3、4,四種狀態(tài)時被調(diào)用;
XMLHttpRequest對象的5種狀態(tài),通常我們只關(guān)心4狀態(tài)。
XMLHttpRequest對象的status屬性表示服務(wù)器狀態(tài)碼,它只有在readyState為4時才能獲取到。
XMLHttpRequest對象的responseText屬性表示服務(wù)器響應(yīng)內(nèi)容,它只有在
readyState為4時才能獲取到!
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- AJAX亂碼與異步同步以及封裝jQuery庫實現(xiàn)步驟詳解
- jquery?ajax實現(xiàn)文件上傳提交的實戰(zhàn)步驟
- 實現(xiàn)AJAX異步調(diào)用和局部刷新的基本步驟
- 利用AjaxControlToolkit實現(xiàn)百度搜索時的下拉列表提示詳細(xì)步驟
- AJAX的原理—如何做到異步和局部刷新【實現(xiàn)代碼】
- 談?wù)凙jax原理實現(xiàn)過程
- 利用iframe實現(xiàn)ajax跨域通信的實現(xiàn)原理(圖解)
- Ajax二級聯(lián)動菜單實現(xiàn)原理及代碼
- js/ajax跨越訪問-jsonp的原理和實例(javascript和jquery實現(xiàn)代碼)
- Ajax實現(xiàn)步驟和原理解析
相關(guān)文章
Bootstrap每天必學(xué)之附加導(dǎo)航(Affix)插件
Bootstrap每天必學(xué)之附加導(dǎo)航(Affix)插件,附加導(dǎo)航即粘貼在屏幕某處實現(xiàn)錨點功能,感興趣的小伙伴們可以參考一下2016-04-04
使用requirejs模塊化開發(fā)多頁面一個入口js的使用方式
這篇文章主要介紹了使用requirejs模塊化開發(fā)多頁面一個入口js的使用方式,需要的朋友可以參考下2017-06-06
Vant+postcss-pxtorem 實現(xiàn)瀏覽器適配功能
這篇文章主要介紹了Vant+postcss-pxtorem 實現(xiàn)瀏覽器適配,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-02-02
使用百度地圖api實現(xiàn)根據(jù)地址查詢經(jīng)緯度
這篇文章主要介紹了使用百度地圖api實現(xiàn)根據(jù)地址查詢經(jīng)緯度的方法,附上實例,推薦給有需要的小伙伴們。2014-12-12
JavaScript實現(xiàn)實時更新系統(tǒng)時間的實例代碼
本文給大家分享javascript實現(xiàn)實時更新系統(tǒng)時間的實例代碼,代碼簡單易懂,非常不錯,具有參考借鑒價值,需要的朋友參考下吧2017-04-04

