json
json简介
- json是通用的,轻量化的 “数据交互格式”,用于 “前后端数据通信”
- json独立于编程语言,本质是一个格式化字符串
- json借用了js对象字面量的语法,简洁高效,已替代了传统的xml格式
- json不是js对象, 但它可以与js对象之间相互转换
关键API
- JSON.stringify(js对象,回调函数[可选],格式化字符[可选]),将js对象序列化成json,例如下列代码将一个js对象序列化成json
const player={
account:"376220510",
name:"烈火点烟",
password:"6350187",
sex:"男",
phone:"18959261401",
};
jsonStr = JSON.stringify(player);
console.log(jsonStr);
可以通过回调函数选择返回的json格式,也可以选择不返回某些内容,例如下列代码
const player={
account:"376220510",
name:"烈火点烟",
password:"6350187",
sex:"男",
phone:"18959261401",
};
jsonStr = JSON.stringify(player,(key, value) => {
switch (key) {
case "sex":
return value === "男" ? "man" : "woman";
case "phone":
return undefined;
default:
return value;
}
});
console.log(jsonStr);
上述代码执行结果中,不返回phone
属性,且将sex
属性值修改成man
返回
XHR
传统XHR创建一个get或者post请求需要以下步骤
- 1.创建对象: new XMLHttpRequest();
- 2.响应类型: xhr.responseType = “json”;
- 3.配置参数: xhr.open(“GET”, url, true);
- 4.请求回调: xhr.onload = () => console.log(xhr.response);
- 5.失败回调: xhr.onerror = () => console.log(“Error”);
- 6.发起请求: xhr.send(null);
- 以下代码实例演示XHR如果发起一个http请求
const xhr = new XMLHttpRequest();
xhr.responseType = "json";
let url = "http://website.io/users.php";
url = "http://website.io/users.php?id=100";
xhr.open("GET", url, true);
xhr.onload = () => {
console.log(xhr.response);
render(xhr.response, btn);
};
xhr.onerror = () => console.log("Error");
xhr.send(null);
fetch
fetch请求基于 promise, 返回一个Promise对象
- 下列代码实例演示fetch方式发起一个http的get请求
let url = "http://website.io/users.php";
url = "http://website.io/users.php?id=2";
fetch(url)
.then(response => response.json())
.then(json => {
console.log(json);
render(json, btn);
})
.catch(err => console.log("Fetch Error", err));
async,await
- async写在函数头,声明该函数为异步函数
- await表示后面是一个异步请求,需要等待结果
- 以下为异步函数实例
async function getUser(btn) {
let url = "http://website.io/users.php";
url = "http://website.io/users.php?id=3";
const response = await fetch(url);
const result = await response.json();
console.log(result);
render(result, btn);
}