Ajax学习笔记,第一节:语法基础
一、概念
1、什么是Ajax
使用浏览器的 XMLHttpRequest 对象 与服务器通信
2、什么是axios
Axios是一个基于Promise的JavaScript库,支持在浏览器和Node.js环境中使用。
相较于Ajax,Axios提供了更多的功能,如拦截请求和响应、转换请求和响应数据、取消请求等,
这使得开发者能够更方便地处理和管理HTTP请求。
Axios相较于Ajax兼容性更好,支持现代浏览器,而Ajax在一些旧版本浏览器中可能会出现一些兼容性问题。
在安全性方面,Axios支持防御XSRF(跨站请求伪造),而Ajax本身并不直接支持这一防御机制。
3、认识URL
·URL的组成:协议,域名,资源路径
(URL 组成有很多部分,我们先掌握这3个重要的部分即可)
·http协议,超文本传输协议。
规定了浏览器和服务器传递数据的格式
·域名,标记服务器在互联网当中的方位,网络中有很多服务器,你想访问哪一台,就需要知道它的域名。
·资源路径,一个服务器内有多个资源,用于标识你要访问的资源具体的位置
4、准备
https://www.apifox.cn/apidoc/project-1937884
这里 有 现成的后端服务,我们在练习时直接使用即可
二、Axios使用
1、初步使用
1> 引入 axios.js 文件到自己的网页中
https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js
2> 语法:
axios({
url: '请求路径',
method: '请求方法',
data:{
参数名:值
}
}).then((res)=>{
//对服务器返回的数据做处理
});
<body>
<h3>1、省份列表</h3>
<p class="my-provs"></p>
<h3>新闻列表</h3>
<p class="my-news"></p>
<script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
<script>
axios({
url: "https://hmajax.itheima.net/api/province"
}).then((res) => {
console.log(res);
if (res != undefined) {
let provList = res.data.list;
document.querySelector(".my-provs").innerHTML = provList.join("<br>");
}
});
axios({
url: "https://hmajax.itheima.net/api/news"
}).then((res) => {
console.log(res);
if (res != undefined) {
let newsList = res.data.data;
let newsInnerHtml = "";
newsList.forEach(ele => {
newsInnerHtml = newsInnerHtml + " <a>" + ele.title + "</a><br><img src=" + ele.img + "><br/> ";
});
console.log(newsInnerHtml);
document.querySelector(".my-news").innerHTML = newsInnerHtml;
}
})
</script>
</body>
2、携带查询参数
语法:
axios({
url:"请求路径",
params:{
//查询参数 params 或在URL后拼接成?xxx=yyy&ooo=ddd格式
}
}).then((res)=>{
//结果处理
});
//注意:
参数中 当属性名和value位置变量名同名即可简写
<body>
<h3>城市列表:</h3> <input type="text" name="cityname"><input type="button" class="slt-btn" value="点我">
<p class="my-city"></p>
<script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
<script>
let cliBtn = document.querySelector(".slt-btn");
cliBtn.addEventListener('click', () => {
let inputVal = document.querySelector("input[name='cityname']");
axios({
url: "https://hmajax.itheima.net/api/city",
params: {
"pname": inputVal.value
}
}).then(res => {
console.log(res);
if (res != undefined) {
let cityList = res.data.list;
document.querySelector(".my-city").innerHTML = cityList.join("<br/>");
}
})
});
</script>
</body>
3、常用请求方法和数据提交
请求方法是一些固定单词的英文,例如:GET,POST,PUT,DELETE,PATCH
(这些都是http协议规定的),每个单词对应一种对服务器资源要执行的操作
axios内部设置了默认请求方法就是GET
请求方法 | 操作 |
---|
GET | 获取数据 |
POST | 数据提交 |
PUT | 修改数据(全部) |
DELETE | 删除数据 |
PATCH | 修改数据(部分) |
#语法:
axios({
url: '目标资源地址',
method: '请求方法',
data: { //注意这里是data 而不是 params
参数名: 值
}
}).then(result => {
// 对服务器返回的数据做后续处理
})
<body>
<label for="un">用户名:</label><input type="text" name="username" id="un">
<label for="pwd">密码:</label><input type="password" name="password" id="pwd">
<input type="button" value="注册" class="btn">
<script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
<script>
let submitBtn = document.querySelector(".btn");
submitBtn.addEventListener('click', () => {
let username = document.querySelector("#un").value;
let password = document.querySelector("#pwd").value;
if (username != undefined && password != undefined) {
axios({
url: "https://hmajax.itheima.net/api/register",
method: 'POST',
data: {
username,
password
}
}).then(res => {
console.log(res.data);
if (res.data == undefined) {
alert("注册失败");
return;
}
if (res.data.code == '10000') {
alert("账号注册成功");
} else {
alert(res.data.message);
}
});
} else {
alert("请输入用户名和密码");
}
});
</script>
</body>
4、Axios错误处理
##语法:
axios({
// ...请求选项
}).then(result => {
// 处理成功数据
}).catch(error => {
// 处理失败错误
})
<script>
let submitBtn = document.querySelector(".btn");
submitBtn.addEventListener('click', () => {
let username = document.querySelector("#un").value;
let password = document.querySelector("#pwd").value;
if (username != undefined && password != undefined) {
axios({
url: "https://hmajax.itheima.net/api/register",
method: 'POST',
data: {
username,
password
}
}).then(res => {
console.log(res.data);
if (res.data == undefined) {
alert("注册失败");
return;
}
if (res.data.code == '10000') {
alert("账号注册成功");
} else {
alert(res.data.message);
}
}).catch(error => {
console.log(error.message);
console.log(error.response.data);
console.log(error.response.data.message);
alert(error.response.data.message);
});
} else {
alert("请输入用户名和密码");
}
});
</script>
5、form-serialize插件
我们前面收集表单元素的值,是一个个标签获取的
如果一套表单里有很多很多表单元素,如何一次性快速收集出来呢.
使用 form-serialize 插件提供的 serialize 函数就可以办到
语法:
serialize(参数1,参数2)
参数1:要获取的form表单标签对象,要求表单元素需要有name属性,用来作为收集的数据中属性名
参数2:配置对象
hash:
true==>收集出来是一个JS对象结构
false==>收集出来是一个查询对象格式
empty:
true==>收集空值
false==>不收集空值
<body>
<form action="javascript:;" class="my-form">
<input type="text" name="username">
<br>
<input type="text" name="password">
<br>
<input type="button" class="btn" value="提交">
</form>
<script src="./js/form-serialize.js"></script>
<script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
<script>
let btn = document.querySelector(".btn");
btn.addEventListener('click', () => {
let myForm = document.querySelector(".my-form");
const data = serialize(myForm, { hash: true, empty: false });
const { username, password } = data;
axios({
url: "https://hmajax.itheima.net/api/login",
method: "POST",
data: {
username,
password
}
}).then(res => {
alert(res.data.message);
})
})
</script>
</body>
三、Ajax原理解析
1、XMLHttpRequest 简单请求
·AJAX 是浏览器与服务器通信的技术,采用 XMLHttpRequest 对象相关代码
·axios 是对 XHR 相关代码进行了封装,让我们只关心传递的接口参数
#语法:
const xhr = new XMLHttpRequest()
xhr.open('请求方法', '请求url网址')
xhr.addEventListener('loadend', () => {
// 响应结果
console.log(xhr.response)
})
xhr.send()
<h3>省份</h3>
<p class="my_prov"></p>
<script>
const xhr = new XMLHttpRequest();
xhr.open("GET", "http://hmajax.itheima.net/api/province");
xhr.addEventListener("loadend", () => {
console.log(xhr.response);
let res = JSON.parse(xhr.response);
console.log(res);
const my_prov = document.querySelector(".my_prov");
my_prov.innerHTML = res.list.join("<br>")
});
xhr.send();
</script>
##拓展:
进度事件的种类:
进度事件用来描述资源加载的进度,主要由 AJAX 请求<img>、<audio>、<video>、<style>、<link>
等外部资源的加载触发,继承了ProgressEvent接口。它主要包含以下几种事件。
·abort:外部资源中止加载时(比如用户取消)触发。如果发生错误导致中止,不会触发该事件。
·error:由于错误导致外部资源无法加载时触发。
·load:外部资源加载成功时触发。
·loadstart:外部资源开始加载时触发。
·loadend:外部资源停止加载时触发,发生顺序排在error、abort、load等事件的后面。
·progress:外部资源加载过程中不断触发。
·timeout:加载超时时触发。
2、XMLHttpRequest 请求参数(简单参数)
#实现::http://xxxx.com/xxx/xxx?参数名1=值1&参数名2=值2
const xhr2 = new XMLHttpRequest();
xhr2.open("GET", "http://hmajax.itheima.net/api/city?pname=河北省");
//1-3、监听回调
xhr2.addEventListener("loadend", () => {
console.log(xhr2.response);
//JSON解析
let res = JSON.parse(xhr2.response);
console.log(res);
const my_city = document.querySelector(".my_city");
my_city.innerHTML = res.list.join("<br>")
});//监听loadend事件
//1-4、发送请求
xhr2.send();//发送请求
3、XMLHttpRequest 请求参数(多个)
##语法
let queryParams = new URLSearchParams({
"pname": "河北省",
"cname": "邯郸市"
});
let queryString = queryParams.toStrng();
const xhr3 = new XMLHttpRequest();
let queryParams = new URLSearchParams({
"pname": "河北省",
"cname": "邯郸市"
});
xhr3.open("GET", "https://hmajax.itheima.net/api/area?" + queryParams.toString());
xhr3.addEventListener("loadend", () => {
console.log(xhr3.response);
let res = JSON.parse(xhr3.response);
console.log(res);
const my_area = document.querySelector(".my_area");
my_area.innerHTML = res.list.join("<br>")
});
xhr3.send();
4、XMLHttpRequest数据提交
##语法:
xhr4.setRequestHeader("Content-Type", "application/json");
let data = { "username": username, "password": password };
let dataStr = JSON.stringify(data);
xhr4.send(dataStr);
const registBtn = document.querySelector(".btn");
registBtn.addEventListener("click", function () {
let username = document.querySelector("#un").value;
let password = document.querySelector("#pwd").value;
if (username == undefined || password == undefined) {
alert("请输入用户名和密码");
return;
}
const xhr4 = new XMLHttpRequest();
xhr4.open("POST", "https://hmajax.itheima.net/api/register");
xhr4.addEventListener("loadend", () => {
console.log(xhr4.response);
let res = JSON.parse(xhr4.response);
if (res != undefined && res.code != '10000') {
alert(res.message);
} else {
alert("账号注册成功.id为:" + res.data.id);
}
})
xhr4.setRequestHeader("Content-Type", "application/json");
let data = { "username": username, "password": password };
let dataStr = JSON.stringify(data);
xhr4.send(dataStr);
});