随着前端技术的不断发展,javascript 已经成为客户端开发中最常用的语言。而在一些数据交互应用中,json(javascript object notation)已经成为数据传输中最常用的格式之一。在 javascript 中,获取 json 对象是非常常见的操作。
本文将会介绍开发者在 JavaScript 中如何获取 JSON 对象。
- 获取 JSON 字符串
首先,获取 JSON 对象的第一步就是获取 JSON 字符串。在 JavaScript 中,可以通过多种方式获取 JSON 字符串,比如从服务器端获取、通过 Ajax 请求、从本地文件读取等方式。
获取 JSON 字符串的方法如下所示:
// 通过Ajax获取JSON字符串
const xhr = new XMLHttpRequest();
xhr.open('GET', 'json/data.json', true);
xhr.onreadystatechange = function() {
if (xhr.readyState === 4 && xhr.status ===200) {
const jsonStr = xhr.responseText;
console.log(jsonStr);
}
}
xhr.send();
// 从JS对象中获取JSON字符串
const obj = {name: 'Alice', age: 18};
const jsonStr = JSON.stringify(obj);
console.log(jsonStr);
// 从本地文件读取JSON字符串
fetch('data.json')
.then(response => response.json())
.then(data => {
const jsonStr = JSON.stringify(data);
console.log(jsonStr);
})
.catch(err => {
console.log('Error: ', err);
})- 把 JSON 字符串转换为 JSON 对象
获取了 JSON 字符串之后,下一步就是把 JSON 字符串转换为 JSON 对象。在 JavaScript 中,可以使用 JSON.parse() 方法将 JSON 字符串转换为 JSON 对象。
立即学习“Java免费学习笔记(深入)”;
方法如下:
const jsonStr = '{"name": "Alice", "age": 18}';
const jsonObj = JSON.parse(jsonStr);
console.log(jsonObj); // 输出:{name: "Alice", age: 18}- 获取 JSON 对象中的值
获取 JSON 对象中的值有两种方式:点运算符和方括号。对于嵌套的 JSON 对象,还可以使用点或方括号运算符的组合来访问嵌套的属性。
如下所示:
const jsonObj = {name: 'Alice', age: 18, address: {city: 'Shanghai', street: 'Nanjing Road'}};
// 通过点运算符访问JSON对象属性
console.log(jsonObj.name); // 输出:'Alice'
// 通过方括号运算符访问JSON对象属性
console.log(jsonObj['age']); // 输出:18
// 访问嵌套JSON对象中的属性
console.log(jsonObj.address.city); // 输出:'Shanghai'
console.log(jsonObj['address']['street']); // 输出:'Nanjing Road'- 实战应用:获取京东商品信息
以上对 JSON 对象的介绍都是基于理论的讲解,接下来将会通过实战应用帮助开发者更好地理解和应用。
本应用将会通过从京东网站中获取商品信息来实现。下面是获取京东商品信息的主要步骤:
- 获取指定商品的页面 HTML
- 解析 HTML 代码,获取商品信息数据
- 将商品信息数据转换为 JSON 对象
- 通过 JSON 对象展示商品信息
首先,需要获取商品页面的 HTML 代码。在 JavaScript 中,可以通过 Ajax 的方式获取京东商品页面 HTML。
function getHtml(url) {
return new Promise((resolve, reject) => {
const xhr = new XMLHttpRequest();
xhr.open('GET', url, true);
xhr.onreadystatechange = function() {
if (xhr.readyState === 4) {
if (xhr.status >=200 && xhr.status <300 || xhr.status === 304) {
resolve(xhr.responseText);
} else {
reject(new Error(xhr.status));
}
}
}
xhr.send();
});
}
getHtml('https://item.jd.com/10024311241244369.html')
.then(html => {
console.log(html)
})
.catch(err => {
console.log('Error: ', err);
})接着,需要使用正则表达式解析 HTML 代码,获取商品信息数据。
function parseHtml(html) {
const regName = /s*(.*?)
/gi;
const regPrice = /s*¥/gi;
const regImg = /
{
const data = parseHtml(html);
console.log(data);
})
.catch(err => {
console.log('Error: ', err);
})由于商品信息数据是结构化数据,最好将其转换为 JSON 对象。
function parseHtml(html) {
const regName = /s*(.*?)
/gi;
const regPrice = /s*¥/gi;
const regImg = /
{
getHtml(url)
.then(html => {
const data = parseHtml(html);
const json = JSON.stringify(data);
resolve(json);
})
.catch(err => {
reject(err);
})
});
}
getJson('https://item.jd.com/10024311241244369.html')
.then(json => {
console.log(json);
})
.catch(err => {
console.log('Error: ', err);
})最后,可以将商品信息 JSON 对象通过前端页面进行展示。
Get Product Info
总结
JavaScript 中获取 JSON 对象是一项比较基础的技能,也是前端开发的必备技能之一。通过本文的学习,希望读者对于 JavaScript 中如何获取 JSON 对象有更好的了解,同时也能够运用在实际项目中。
java速学教程(入门到精通)
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
下载
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
更多










