ajax学习第三天
1. XMLHttpRequest
1.1 xhr的概念
- 是浏览器提供的js对象,通过它,可以请求服务器上的数据资源,jQuery中的ajax函数,就是基于xhr对象封装出来的
1.2 使用xhr发起get请求
- 步骤
- 创建xhr对象
- 调用open函数
- 调用send函数
- 监听xhr状态
示例
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| </head> |
| |
| <body> |
| <script> |
| |
| var xhr = new XMLHttpRequest(); |
| |
| |
| xhr.open("GET", "http://www.liulongbin.top:3006/api/getbooks"); |
| |
| |
| |
| xhr.send(); |
| |
| |
| |
| xhr.onreadystatechange = function() { |
| |
| |
| if (xhr.readyState === 4 && xhr.status === 200) { |
| |
| console.log(xhr.responseText); |
| } |
| } |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/c46a6/c46a63df481c6920ebb43d6ebaa54c11c8677553" alt="在这里插入图片描述"
1.3 xhr对象的readyState属性
- 表示当前Ajax请求所处的状态,每个Ajax请求必然处于以下状态的一个
值 | 状态 | 说明 |
---|
0 | UNSET | xhr对象已创建,open函数未调用 |
1 | OPENED | open()方法已经被调用 |
2 | HEADERS_RECEIVED | send()方法已调用,响应头已被接收 |
3 | LOADING | 数据接收中,其中response属性已经包含部分数据 |
4 | DONE | Ajax请求完成,数据已经彻底传输成功或者失败 |
1.4 使用xhr发起带参数的get请求
- 在调用open()函数期间,为url地址拼接参数字符串(查询字符串)
| xhr.open("GET","http://www.liulongbin.top:3006/api/getbooks?id=1") |
- ?id=1为url后面拼接的字符串,称为查询字符串
示例
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| </head> |
| |
| <body> |
| <script> |
| var xhr = new XMLHttpRequest(); |
| |
| |
| xhr.open("GET", "http://www.liulongbin.top:3006/api/getbooks?id=1"); |
| xhr.send(); |
| xhr.onreadystatechange = function() { |
| if (xhr.readyState === 4 && xhr.status === 200) { |
| console.log(xhr.responseText); |
| } |
| } |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/8bdb3/8bdb318abba222d211fad524c6d44fbaaa45c77e" alt="在这里插入图片描述"
1.5 查询字符串
| "http://www.liulongbin.top:3006/api/getbooks?id=1&bookname=西游记" |
1.6 get请求携带参数的本质
| $.get("url",{name:'666',age:18},function(){}) |
| |
| $.get("url?name:666&age:18",function(){}) |
| $.ajax(method:"get",url:"url",data{name:'666',age:18},success:function(){}) |
| |
| $.ajax(method:"get",url:"url?name:666&age:18",success:function(){}) |
1.7 URL 编码
- 场景:在url地址中,只允许出现英文相关的字母、标点符号、数字,不允许出现中午字符,如果出现,需要对中文字符进行编码
- 使用英文字符(安全的字符)表示非英文字符(不安全的字符)
- 编码前
| xhr.open("GET", "http://www.liulongbin.top:3006/api/getbooks?id=1&bookname=西游记"); |
data:image/s3,"s3://crabby-images/e40a9/e40a985de37d9d7c5868cbdf89c7aa85c2f0a4ec" alt="在这里插入图片描述"
1.8 URL的编码和解码
- 编码函数:encodeURL()
- 解码函数:decodeURL()
示例
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| </head> |
| |
| <body> |
| <script> |
| var str = '我是编码函数'; |
| |
| |
| var result = encodeURI(str); |
| |
| console.log(result); |
| |
| |
| |
| var result2 = decodeURI(result.substr(9)); |
| console.log(result2); |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/9bb5d/9bb5d8540fbc72db9cdadf67b71da6a8d433c94b" alt="在这里插入图片描述"
1.9 使用xhr发起post请求
- 步骤
- 创建xhr对象
- 调用open()函数
- 设置Content-Type属性(固定写法)
- 调用send()函数,指定要传输的数据(已查询字符串的格式)
- 监听onreadystatechange 事件
- 示例
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| </head> |
| |
| <body> |
| <script> |
| |
| |
| var xhr = new XMLHttpRequest(); |
| |
| |
| xhr.open('post', 'http://www.liulongbin.top:3006/api/addbook'); |
| |
| |
| xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); |
| |
| |
| |
| xhr.send('bookname=一念永恒&author=耳根&publisher=上海图书出版社'); |
| |
| |
| xhr.onreadystatechange = function() { |
| if (xhr.readyState === 4 && xhr.status === 200) { |
| console.log(xhr.responseText); |
| } |
| } |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/5a9e2/5a9e211dd26d62134465c2da3fbe3dbcaf81f998" alt="在这里插入图片描述"
2. 数据交换格式
- 定义:服务器端与客户端之间**进行数据传输和交换的格式**
- 前端提及的交换格式
2.1 XML
- XML(EXtensible Markup Language),可扩展标记语言,与html一样,也是页面标记语言
2.2 XML与HTML的区别
- HTML用于描述网页上的内容,是网页内容的载体
- XML被设计用于传输和存储数据,是数据的载体
2.3 XML的缺点
data:image/s3,"s3://crabby-images/f77b4/f77b4c4eed8df80c381c033f0b5a83a2f368c5df" alt="在这里插入图片描述"
2.4 JSON
- 定义:JSON(JavaScript Object Notation),即JavaScript对象表示法,json就是JavaScript对象和数组的字符串表示法****,本质是字符串
- 作用:作用上类型XML,但比XML更小,更快,更容易解析
2.4.1 JSON的两种结构
2.4.2 JSON的对象结构
data:image/s3,"s3://crabby-images/d93ac/d93acab9c0f3d3896a3ecdb6946cff46f51faa48" alt="在这里插入图片描述"
2.4.3 JSON的数组结构
data:image/s3,"s3://crabby-images/89989/899898bceeed841f28056b33b4b62d40237c42d0" alt="在这里插入图片描述"
注意点
data:image/s3,"s3://crabby-images/d4e1a/d4e1aee0f15289efe025dd6c402b391e67e43419" alt="在这里插入图片描述"
2.5 json和js对象
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| </head> |
| |
| <body> |
| <script> |
| |
| |
| var obj = { |
| key: 100, |
| value: 50 |
| } |
| |
| |
| |
| var json = '{"key":100,"value":50}'; |
| </script> |
| </body> |
| |
| </html> |
2.5.1 json和js对象的转换
- 将json对象转换成js对象(JSON.parse())
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| </head> |
| |
| <body> |
| <script> |
| |
| |
| var json = '{"a":"hello","b":"world"}'; |
| |
| |
| |
| var obj = JSON.parse(json); |
| |
| console.log(obj); |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/87681/8768116b7218a10ee8dbdbf85fc9de442ad7ff9e" alt="在这里插入图片描述"
- 将 js对象转换成 JSON对象(JSON.stringify())
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| </head> |
| |
| <body> |
| <script> |
| |
| |
| var obj = { |
| a: 'world', |
| b: 'hello' |
| } |
| |
| |
| |
| var json = JSON.stringify(obj); |
| |
| console.log(json); |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/287ec/287ec1807fcfab98df591f18a2068c9f75bf5a61" alt="在这里插入图片描述"
发起get请求
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| </head> |
| |
| <body> |
| <script> |
| |
| |
| var xhr = new XMLHttpRequest(); |
| |
| |
| xhr.open("GET", "http://www.liulongbin.top:3006/api/getbooks"); |
| |
| |
| |
| xhr.send(); |
| |
| xhr.onreadystatechange = function() { |
| if (xhr.readyState === 4 && xhr.status === 200) { |
| console.log(xhr.responseText); |
| |
| |
| var obj = JSON.parse(xhr.responseText); |
| |
| console.log(obj); |
| } |
| } |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/fd0ed/fd0ed18642dcc78f06179ca62aa181f53d01e0f9" alt="在这里插入图片描述"
2.6 序列化和反序列化
- 将数据对象转换成字符串的过程,**称为序列化,**JSON.stringify()叫做JSON的序列化
- 将字符串类型转换成数据对象的过程,**叫做反序列化,**JSON.parse()叫做JSON的反序列化
2.7 封装一个自己的Ajax函数
| |
| |
| function switchDate(data) { |
| var arr = []; |
| for (k in data) { |
| var str = k + '=' + data[k]; |
| arr.push(str); |
| } |
| |
| return arr.join("&"); |
| |
| } |
| |
| |
| |
| function myajax(obj) { |
| |
| |
| |
| |
| var qs = switchDate(obj.data); |
| var xhr = new XMLHttpRequest(); |
| if (obj.method.toUpperCase() === 'GET') { |
| xhr.open("GET", obj.url + '?' + qs); |
| xhr.send(); |
| } else if (obj.method.toUpperCase() === 'POST') { |
| xhr.open("POST", obj.url); |
| xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); |
| xhr.send(qs); |
| } |
| |
| xhr.onreadystatechange = function() { |
| if (xhr.readyState === 4 && xhr.status === 200) { |
| var jsonstr = xhr.responseText; |
| var jsobj = JSON.parse(jsonstr); |
| obj.success(jsobj); |
| } |
| } |
| |
| |
| } |
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| <script src="./js/MyAjax.js"></script> |
| </head> |
| |
| <body> |
| <script> |
| myajax({ |
| method: "GET", |
| url: "http://www.liulongbin.top:3006/api/getbooks", |
| data: { |
| id: 1 |
| }, |
| success: function(res) { |
| console.log(res); |
| } |
| }) |
| |
| myajax({ |
| method: "post", |
| url: 'http://www.liulongbin.top:3006/api/addbook', |
| data: { |
| bookname: '一念永hen', |
| author: '耳根', |
| publisher: '上海图书出版社' |
| }, |
| success: function(res) { |
| console.log(res); |
| } |
| }) |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/94627/94627afb49655cefa887a9672ce69ac9cca14ba0" alt="在这里插入图片描述"
3. XMLHttpRequest Level2的新特性
3.1 旧版xhr的缺点
- 只支持文本数据的传输,无法用来读取和上传文件
- 传输和接收数据时,没有进度信息,只能提示有没有完成
3.2 xhr 2的新功能
- 可以设置HTTP请求的时限
- 可以使用FormData对象管理表单数据
- 可以上传文件
- 可以获得数据传输的进度信息
3.3 设置HTTP请求时限
| xhr.ontimeout=function(){} |
示例
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| </head> |
| |
| <body> |
| <script> |
| var xhr = new XMLHttpRequest(); |
| |
| |
| xhr.timeout = 30; |
| |
| |
| |
| xhr.ontimeout = function() { |
| console.log("请求超时"); |
| } |
| |
| xhr.open("get", "http://www.liulongbin.top:3006/api/getbooks"); |
| xhr.send(); |
| |
| xhr.onreadystatechange = function() { |
| if (xhr.readyState === 4 && xhr.status === 200) { |
| console.log(xhr.responseText); |
| } |
| } |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/5e12d/5e12d07cd71f86fe022c7e8bda34a3a0a9bce33f" alt="在这里插入图片描述"
3.4 xhr2的FormData对象
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| </head> |
| |
| <body> |
| <script> |
| |
| |
| var fd = new FormData(); |
| |
| |
| |
| fd.append("id", "2"); |
| |
| |
| |
| var xhr = new XMLHttpRequest(); |
| |
| xhr.open("post", "http://www.liulongbin.top:3006/api/formdata"); |
| |
| |
| xhr.send(fd); |
| |
| xhr.onreadystatechange = function() { |
| if (xhr.readyState === 4 && xhr.status === 200) { |
| console.log(JSON.parse(xhr.responseText)); |
| } |
| } |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/9b6ee/9b6eee2ebec8750259372b13fc3946b25ab921ee" alt="在这里插入图片描述"
示例:实现表单数据的收集(注意阻止表单的默认提交行为)
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| </head> |
| |
| <body> |
| <form id="form1"> |
| 姓名:<input type="text" name="uname"> 密码: |
| <input type="password" name="upwd"> |
| <button type="submit">提交</button> |
| |
| </form> |
| |
| <script> |
| |
| |
| |
| var form1 = document.querySelector("#form1"); |
| |
| form1.addEventListener("submit", function(e) { |
| |
| |
| |
| e.preventDefault(); |
| |
| var fd = new FormData(form1); |
| |
| var xhr = new XMLHttpRequest(); |
| |
| xhr.open("post", "http://www.liulongbin.top:3006/api/formdata"); |
| |
| xhr.send(fd); |
| |
| xhr.onreadystatechange = function() { |
| if (xhr.readyState === 4 && xhr.status === 200) { |
| console.log(JSON.parse(xhr.responseText)); |
| } |
| } |
| }) |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/b2947/b29475389ab45775ff7d764d9c56e00086ea3b76" alt="在这里插入图片描述"
3.5 xhr实现文件上传
data:image/s3,"s3://crabby-images/5e519/5e519857fa0df4a99ac1dc48e3de33e213d4a47d" alt="在这里插入图片描述"
示例
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| </head> |
| |
| <body> |
| |
| <input type="file" id="select"> |
| |
| |
| <button id="upload">上传文件</button> |
| |
| |
| <img src="" alt=""> |
| |
| <script> |
| |
| |
| var upload = document.querySelector("#upload"); |
| var select = document.querySelector("#select"); |
| |
| |
| |
| upload.addEventListener("click", function() { |
| |
| if (select.files.length > 0) { |
| |
| |
| |
| var fd = new FormData(); |
| |
| fd.append("avatar", select.files[0]); |
| |
| |
| |
| var xhr = new XMLHttpRequest(); |
| |
| xhr.open("post", 'http://www.liulongbin.top:3006/api/upload/avatar'); |
| |
| xhr.send(fd); |
| |
| xhr.onreadystatechange = function() { |
| if (xhr.readyState === 4 && xhr.status === 200) { |
| var res = JSON.parse(xhr.responseText); |
| |
| |
| if (res.status === 200) { |
| console.log(res); |
| |
| |
| document.querySelector("img").src = 'http://www.liulongbin.top:3006' + res.url; |
| } else { |
| alert("文件上传失败"); |
| } |
| } |
| } |
| |
| } else { |
| return alert("请选择要上传的文件"); |
| } |
| |
| }) |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/d962a/d962a5ed193b4cf875927e67717407f6a37c8b81" alt="在这里插入图片描述"
3.6 显示上传的进度
| xhr.upload.onprogress = function(e) { |
| |
| if (e.lengthComputable) { |
| |
| |
| |
| console.log(Math.ceil(e.loaded / e.total * 100)); |
| } |
| } |
示例
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| </head> |
| |
| <body> |
| |
| <input type="file" id="select"> |
| |
| |
| <button id="upload">上传文件</button> |
| |
| |
| <img src="" alt=""> |
| |
| <script> |
| |
| |
| var upload = document.querySelector("#upload"); |
| var select = document.querySelector("#select"); |
| |
| |
| |
| upload.addEventListener("click", function() { |
| |
| if (select.files.length > 0) { |
| |
| |
| |
| var fd = new FormData(); |
| |
| fd.append("avatar", select.files[0]); |
| |
| |
| |
| var xhr = new XMLHttpRequest(); |
| |
| |
| |
| xhr.upload.onprogress = function(e) { |
| |
| if (e.lengthComputable) { |
| |
| |
| |
| console.log(Math.ceil(e.loaded / e.total * 100)); |
| } |
| } |
| |
| xhr.open("post", 'http://www.liulongbin.top:3006/api/upload/avatar'); |
| |
| xhr.send(fd); |
| |
| xhr.onreadystatechange = function() { |
| if (xhr.readyState === 4 && xhr.status === 200) { |
| var res = JSON.parse(xhr.responseText); |
| |
| |
| if (res.status === 200) { |
| console.log(res); |
| |
| |
| document.querySelector("img").src = 'http://www.liulongbin.top:3006' + res.url; |
| } else { |
| alert("文件上传失败"); |
| } |
| } |
| } |
| |
| } else { |
| return alert("请选择要上传的文件"); |
| } |
| |
| }) |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/3ece3/3ece372357ac89a7dcf656f51a2dd8add3bb6410" alt="在这里插入图片描述"
3.7 进度条ui(使用了bs3框架)
| <link rel="stylesheet" href="./lib/bootstrap.css"> |
| |
| |
| |
| <div class="progress" style="width:300px"> |
| <div class="progress-bar progress-bar-striped active" style="width: 0"> |
| 0% |
| </div> |
| </div> |
| xhr.upload.onprogress = function(e) { |
| |
| if (e.lengthComputable) { |
| |
| |
| |
| console.log(Math.ceil(e.loaded / e.total * 100)); |
| |
| |
| $(".progress .progress-bar").css({ |
| width: Math.ceil(e.loaded / e.total * 100) + '%' |
| }).html(Math.ceil(e.loaded / e.total * 100) + '%'); |
| } |
| } |
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| <link rel="stylesheet" href="./lib/bootstrap.css"> |
| <script src="./lib/jquery.js"></script> |
| </head> |
| |
| <body> |
| |
| <input type="file" id="select"> |
| |
| |
| <button id="upload">上传文件</button> |
| |
| |
| <img src="" alt=""> |
| |
| |
| |
| |
| <div class="progress" style="width:300px"> |
| <div class="progress-bar progress-bar-striped active" style="width: 0"> |
| 0% |
| </div> |
| </div> |
| |
| <script> |
| |
| |
| var upload = document.querySelector("#upload"); |
| var select = document.querySelector("#select"); |
| |
| |
| |
| upload.addEventListener("click", function() { |
| |
| if (select.files.length > 0) { |
| |
| |
| |
| var fd = new FormData(); |
| |
| fd.append("avatar", select.files[0]); |
| |
| |
| |
| var xhr = new XMLHttpRequest(); |
| |
| |
| |
| xhr.upload.onprogress = function(e) { |
| |
| if (e.lengthComputable) { |
| |
| |
| |
| console.log(Math.ceil(e.loaded / e.total * 100)); |
| |
| |
| $(".progress .progress-bar").css({ |
| width: Math.ceil(e.loaded / e.total * 100) + '%' |
| }).html(Math.ceil(e.loaded / e.total * 100) + '%'); |
| } |
| } |
| |
| xhr.open("post", 'http://www.liulongbin.top:3006/api/upload/avatar'); |
| |
| xhr.send(fd); |
| |
| xhr.onreadystatechange = function() { |
| if (xhr.readyState === 4 && xhr.status === 200) { |
| var res = JSON.parse(xhr.responseText); |
| |
| |
| if (res.status === 200) { |
| console.log(res); |
| |
| |
| document.querySelector("img").src = 'http://www.liulongbin.top:3006' + res.url; |
| } else { |
| alert("文件上传失败"); |
| } |
| } |
| } |
| |
| } else { |
| return alert("请选择要上传的文件"); |
| } |
| |
| }) |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/b32e9/b32e9cabd59aeaf1b5a69850b1e79aef87be82e6" alt="在这里插入图片描述"
3.8 监听文件上传成功
| |
| xhr.upload.onload = function() { |
| $(".progress .progress-bar").removeClass().addClass("progress-bar progress-bar-success"); |
| } |
data:image/s3,"s3://crabby-images/394cf/394cf8922b63e3399f2249e69a802e7c4677eb40" alt="在这里插入图片描述"
4. jQuery实现文件上传
| |
| |
| $(document).ajaxStart(function() { |
| |
| $("#loading").show(); |
| }) |
| |
| |
| |
| $(document).ajaxComplete(function() { |
| $("#loading").hide(); |
| |
| }) |
| |
| contentType: false, |
| |
| processData: false, |
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| |
| <script src="./lib/jquery.js"></script> |
| </head> |
| |
| <body> |
| |
| <input type="file" id="select"> |
| |
| |
| <button id="upload">上传文件</button> |
| |
| <img src="./loading.gif" alt="" style="display: none;" id="loading"> |
| |
| |
| <br> |
| <img src="" alt="" id="pic"> |
| |
| |
| |
| |
| <script> |
| |
| |
| $(function() { |
| $("#upload").on("click", function() { |
| |
| if ($("#select")[0].files.length > 0) { |
| var fd = new FormData(); |
| fd.append("avatar", $("#select")[0].files[0]); |
| |
| |
| |
| $(document).ajaxStart(function() { |
| |
| $("#loading").show(); |
| }) |
| |
| |
| |
| $(document).ajaxComplete(function() { |
| $("#loading").hide(); |
| |
| }) |
| |
| $.ajax({ |
| method: "post", |
| url: 'http://www.liulongbin.top:3006/api/upload/avatar', |
| data: fd, |
| |
| contentType: false, |
| |
| processData: false, |
| success: function(res) { |
| console.log(res); |
| $("#pic").attr("src", 'http://www.liulongbin.top:3006' + res.url) |
| } |
| }) |
| |
| |
| } else { |
| return alert("请先选择文件"); |
| } |
| }) |
| }) |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/4b155/4b155210d0cb49447ac3e97836ddce9df4d8cef5" alt="在这里插入图片描述"
5. axios
- 专注于网络数据请求的库
- 相当于xhr,axios简单易用
- 相对于jQuery,更加轻量化
5.1 使用axios发起get请求
| axios.get('url',{params:{参数}}).then(回调函数) |
示例
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| |
| <script src="./lib/axios.js"></script> |
| </head> |
| |
| <body> |
| |
| <button id="btn">get请求</button> |
| |
| |
| <script> |
| document.querySelector("#btn").addEventListener("click", function() { |
| |
| |
| var url = "http://www.liulongbin.top:3006/api/get"; |
| var data = { |
| name: "zs", |
| age: 18, |
| } |
| axios.get(url, { |
| params: data |
| }).then(function(res) { |
| console.log(res); |
| |
| |
| console.log(res.data); |
| }) |
| }) |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/127f5/127f5523cfe9c495383fa19ddcef51439328cb22" alt="在这里插入图片描述"
5.2 使用axios发起post请求
| axios.post('url',{参数}).then(回调函数) |
示例
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| <script src="./lib/axios.js"></script> |
| </head> |
| |
| <body> |
| <button id="btn">post请求</button> |
| |
| <script> |
| document.querySelector("#btn").addEventListener("click", function() { |
| |
| |
| var url = 'http://www.liulongbin.top:3006/api/post'; |
| var data = { |
| id: 1, |
| name: "k" |
| } |
| |
| axios.post(url, data).then(function(res) { |
| console.log(res.data); |
| }) |
| }) |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/2e734/2e7342995461338d1278bbbdbe8eefa5439da2a9" alt="在这里插入图片描述"
5.3 直接使用axios发起get和post请求
| axios({ |
| method:'请求类型', |
| url:'请求地址', |
| data:{ |
| post请求的参数 |
| }, |
| params:{ |
| get请求参数 |
| } |
| }).then(回调函数) |
示例
| <!DOCTYPE html> |
| <html lang="en"> |
| |
| <head> |
| <meta charset="UTF-8"> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>Document</title> |
| <script src="./lib/axios.js"></script> |
| </head> |
| |
| <body> |
| <button id="btn1">get请求</button> |
| <button id="btn2">post请求</button> |
| |
| <script> |
| |
| document.querySelector("#btn1").addEventListener("click", function() { |
| axios({ |
| method: 'get', |
| url: 'http://www.liulongbin.top:3006/api/get', |
| params: { |
| name: "k", |
| age: 18 |
| } |
| }).then(function(res) { |
| console.log(res.data); |
| }) |
| }) |
| |
| |
| |
| document.querySelector("#btn2").addEventListener("click", function() { |
| axios({ |
| method: 'post', |
| url: 'http://www.liulongbin.top:3006/api/post', |
| data: { |
| id: 1, |
| name: "666" |
| } |
| }).then(function(res) { |
| console.log(res.data); |
| }) |
| }) |
| </script> |
| </body> |
| |
| </html> |
data:image/s3,"s3://crabby-images/46ac9/46ac98023b4741308d732b47dca4fd780fec45b1" alt="在这里插入图片描述"
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)