| ajax({ |
| url:"http://localhost:3000/users", |
| method:"POST", |
| data:"username=lala&password=111", |
| headers:{ |
| "content-type":"application/x-www-form-urlencoded" |
| }, |
| success:function(res){ |
| console.log("success:",res) |
| }, |
| error:function(err){ |
| console.log("error:",err) |
| } |
| }) |
复制
- ajax:这里的ajax是封装的函数名,这个函数名随便起,函数定义是在js代码中;
- url:数据请求的链接url一定要有;
- method:为了让这种封装方式适用于各种请求方式,要在调用的时候有一个method参数来接收请求方式;
- method:接收各种请求方式:get、post、put、patch、delete;
- data:post方式等不同方式要传输的数据,放在data里;
- async:是否异步,参数可传可不传,不传默认是true:异步;false:同步;
- headers:因为我们在用post方式时,传给后端的信息有两种方式:一种是表单格式,一种是json格式,所以要有这个headers参数,放信息格式;
- success和error是回调函数,一个成功的回调,一个失败的回调,函数调用会在js代码中实现;
- 最后因为参数多,我们可以用对象的方式将它们放在一起,传进ajax这个函数里;
| |
| |
| |
| function queryStringify(obj) { |
| let str = '' |
| for (let k in obj) str += `${k}=${obj[k]}&` |
| |
| |
| |
| |
| return str.slice(0, -1) |
| } |
| |
| |
| |
| |
| function ajax(options) { |
| |
| let defaultoptions = { |
| url: "", |
| method: "GET", |
| async: true, |
| data: {}, |
| headers: {}, |
| success: function () { }, |
| error: function () { } |
| } |
| |
| let { url, method, async, data, headers, success, error } = { |
| ...defaultoptions, |
| ...options |
| } |
| console.log(url, method, async, data, headers, success, error) |
| |
| |
| if (typeof data === 'object' && headers["content-type"]?.indexOf("json") > -1) { |
| data = JSON.stringify(data) |
| } |
| else { |
| |
| data = queryStringify(data) |
| } |
| |
| |
| if (/^get$/i.test(method) && data) url += '?' + data |
| |
| |
| const xhr = new XMLHttpRequest() |
| xhr.open(method, url, async) |
| xhr.onload = function () { |
| if (!/^2\d{2}$/.test(xhr.status)) { |
| |
| error(`错误状态码:${xhr.status}`) |
| return |
| } |
| |
| |
| |
| |
| |
| try { |
| let result = JSON.parse(xhr.responseText) |
| success(result) |
| } catch (err) { |
| error('解析失败 ! 因为后端返回的结果不是 json 格式字符串') |
| } |
| } |
| |
| |
| |
| |
| |
| |
| for (let k in headers) xhr.setRequestHeader(k, headers[k]) |
| |
| if (/^get$/i.test(method)) { |
| xhr.send() |
| } else { |
| xhr.send(data) |
| } |
| |
| |
| } |
复制
| <body> |
| <script src="./util.js"></script> |
| <script> |
| |
| |
| ajax({ |
| url:"http://localhost:3000/users", |
| success:function(res){ |
| console.log("success:",res) |
| }, |
| error:function(err){ |
| console.log("error:",err) |
| } |
| }) |
| </script> |
| </body> |
复制
| <body> |
| <script src="./util.js"></script> |
| <script> |
| |
| |
| ajax({ |
| url:"http://localhost:3000/users", |
| method:"POST", |
| data:"username=lala&password=111", |
| headers:{ |
| "content-type":"application/x-www-form-urlencoded" |
| }, |
| success:function(res){ |
| console.log("success:",res) |
| }, |
| error:function(err){ |
| console.log("error:",err) |
| } |
| }) |
| </script> |
| </body> |
复制
| if (typeof data === 'object' && headers["content-type"]?.indexOf("json") > -1) { |
| data = JSON.stringify(data) |
| } |
| else { |
| |
| data = queryStringify(data) |
| } |
复制
这个headers["content-type"]后面的问号的含义是:
- 如果前面为假,就不执行后面这个“.”的方法;
- 所以这句代码的含义是:如果headers["content-type"]为假,那么就不调用这个indexOf(“json”)这个方法,代码继续执行;
- 这样保证即使前面为假,代码也可以往下执行,只是不调用这个方法了而已;