ajax

ajax不是新的编程语言,而是一种使用现有标准的新方法。

AJAX 是一种用于创建快速动态网页的技术。

通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。

传统的网页(不使用 AJAX)如果需要更新内容,必需重载整个网页面。

XMLHttpRequest 是 AJAX 的基础

使用ajax

​ 1、必须基于xhr对象,创建xhr对象

var xhr = null;
// xhr = new XMLHttpRequest();  //w3c规范以后
// xhr = new ActiveXObject("Microsoft.XMLHTTP"); //ie5及以前
if(window.XMLHttpRequest){    //做兼容性处理,看window底下是否含有XMLHttpRequest对象
	xhr = new XMLHttpRequest()
}else{
	xhr = new ActiveXObject("Microsoft.XMLHTTP");
}

​ 2、绑定监听函数

xhr.onreadystatechange = function(){
	//console.log('XHR的状态码发生改变');
	//console.log(xhr.readyState);   状态码
	//console.log(xhr.status);    响应码
	//console.log(xhr.responseText)  服务端返回的内容
}

​ 3、建立连接

xhr.open(method,url,boolean)

​ 4、发送请求

xhr.send()

xhr.readyState 有五个步骤,分别对应的是01234
0 未建立连接(请求未初始化,在调用open()之前)
1 请求以提出(调用send()之前)
2 请求已发送(这里通常可以从响应得到内容头部)
3 请求处理中(响应中通常有部分数据可用,但是服务器还没有完成响应)
4 ajax请求发送并且响应完成(可以访问服务器响应并使用它)

使用js实现ajax请求

get请求
1、准备好后台
2、添加html页面

<h3>注册新用户</h3>
用户名: <input type="text" id="username">
<span id="uname_msg"></span>
<br>
密码:<input type="text">
<br>
<button>提交</button>

3、添加js做ajax请求

document.getElementById("username").onblur = function(){
	// console.log('blur')
	var uname = this.value
	if(uname == ""){   //严谨的正则判断,如果正则都不能通过,肯定不能发送ajax请求
		return;
	}
	// 1.创建
	var xhr = null;
	if(window.XMLHttpRequest){    //做兼容性处理,看window底下是否含有XMLHttpRequest对象
		xhr = new XMLHttpRequest()
	}else{
		xhr = new ActiveXObject("Microsoft.XMLHTTP");
	}
	// 2.绑定监听函数
	xhr.onreadystatechange = function(){
		// console.log(xhr.responseText);  //会输出4次,因为状态码改变了4次
		if(xhr.readyState == 4){   //ajax请求已经完成
			if(xhr.status == 200){   //这是一个成功的请求
				console.log(xhr.responseText) //服务端的返回值
				responseText(xhr.responseText)
			}
		}
	}
	// 3.建立连接
	xhr.open("GET","04.php?username=" + uname,true);
	// 4.发送请求
	xhr.send(null) //get请求的参数都已经到地址栏中,所以这里可以发送空

}


function responseText(txt){
	var span = document.getElementById("uname_msg");
	if(txt == "0"){
		span.innerHTML = "该用户名可以使用";
		span.style.color = "green";
	}else if(txt == "1"){
		span.innerHTML = "该用户名已经被占用";
		span.style.color = "red";
	}else{
		span.innerHTML = "未知错误";
		span.style.color = "red";
	}
}

post请求

与get请求的第3,4步不同

// 3.建立连接
	xhr.open("POST","05.php",true);

	// 3.5post请求发送之前,必须设定发送的格式
	xhr.setRequestHeader("content-type","application/x-www-form-urlencoded");

	// 4.发送请求
	xhr.send("stuName=" + username.value + "&score=" + userscore.value)  //post参数放在send中
 }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值