标签:字符 strong 执行 情况 button 报错 === als creat
Ajax即“Asynchronous JavaScript and XML”(异步的JavaScript与XML技术)
Ajax 是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。
XMLHttpRequest对象是浏览器提供的一个API,用来顺畅地向服务器发送请求并解析服务器响应,当然整个过程中,浏览器页面不会被刷新。
注意,Ajax 只能向同源网址(协议、域名、端口都相同)发出 HTTP 请求,如果发出跨域请求,就会报错。
var xhr=new XMLHttpRequest()
xhr.onreadystatechange=function(){
if(xhr.readyState===4){
if(xhr.status===200){
console.log(xhr.responseText)
}else{
console.log(new Error(xhr.statusText))
}
}
}
xhr.open(‘GET‘,‘./ajax.html‘)
xhr.send()
1.创建XMLHttpRequest对象
var xhr = new XMLHttpRequest();
兼容各个浏览器的创建方法:
function createRequest (){
try {
xhr = new XMLHttpRequest();
}catch (tryMS){
try {
xhr = new ActiveXObject("Msxm12.XMLHTTP");
} catch (otherMS) {
try {
xhr = new ActiveXObject("Microsoft.XMLHTTP");
}catch (failed) {
xhr = null;
}
}
}
return xhr;
}
2.准备请求
xhr.open(method,url,async);
3.发送请求
xhr.send();
send() 方法的参数可以是任何你想发送给服务器的内容
4.处理响应
xhr.onreadystatechange=function(){
if(xhr.readyState===4){
if(xhr.status===200){
console.log(xhr.responseText)
}else{
console.log(new Error(xhr.statusText))
}
}
}
onreadystatechange :当处理过程发生变化的时候执行onreadystatechange对应的函数
readyState状态值
open()
方法还没有被调用。open()
方法已经调用,但是实例的send()
方法还没有调用,仍然可以使用实例的setRequestHeader()
方法,设定 HTTP 请求的头信息。send()
方法已经调用,并且服务器返回的头信息和状态码已经收到。responseType
属性等于text
或者空字符串,responseText
属性就会包含已经收到的部分信息。responseText:服务器以文本字符的形式返回
responseXML:获得 XML形式的响应数据
XMLHttpRequest 的实例属性细节:阮一峰:XMLHttpRequest 对象
myButton=document.getElementById(‘myButton‘)
myButton.addEventListener(‘click‘,(e)=>{
let xhr=new XMLHttpRequest()
xhr.onreadystatechange=()=>{
if( xhr.readyState===4){
console.log("请求响应都完毕了")
if( xhr.status>=200&& xhr.status<300){
console.log("请求成功")
}else if( xhr.status>=400){
console.log("请求失败")
}
}
}
xhr.open(‘GET‘,‘/xxx‘)
xhr.send()
})
当发送请求的时候,就会根据xml.open(‘GET‘,‘/xxx‘)
找到对应的请求路径。在本文是找到/xxx
路径,然后返回所请求的数据,在浏览器运行结果如下。
标签:字符 strong 执行 情况 button 报错 === als creat
原文地址:https://www.cnblogs.com/qfstudy/p/9497639.html