简介
在本实验中,我们将探索如何使用 JavaScript 从对象的键值对生成查询字符串。我们将在 Object.entries()
上使用 Array.prototype.reduce()
方法来创建查询字符串,并根据 queryString
的长度确定要使用的合适符号。在本实验结束时,你将能够为你的 Web 应用程序高效地生成查询字符串。
This tutorial is from open-source community. Access the source code
💡 本教程由 AI 辅助翻译自英文原版。如需查看原文,您可以 切换至英文原版
在本实验中,我们将探索如何使用 JavaScript 从对象的键值对生成查询字符串。我们将在 Object.entries()
上使用 Array.prototype.reduce()
方法来创建查询字符串,并根据 queryString
的长度确定要使用的合适符号。在本实验结束时,你将能够为你的 Web 应用程序高效地生成查询字符串。
要将对象转换为查询字符串,请使用 objectToQueryString()
函数,该函数会根据给定对象的键值对生成查询字符串。
该函数的工作原理如下:
Object.entries()
上使用 Array.prototype.reduce()
从 queryParameters
创建查询字符串。queryString
的长度确定 symbol
是 ?
还是 &
。val
是字符串时,才将其连接到 queryString
。queryParameters
为假值时,返回 queryString
或空字符串。以下是 objectToQueryString()
函数的代码:
const objectToQueryString = (queryParameters) => {
return queryParameters
? Object.entries(queryParameters).reduce(
(queryString, [key, val], index) => {
const symbol = queryString.length === 0 ? "?" : "&";
queryString +=
typeof val === "string" ? `${symbol}${key}=${val}` : "";
return queryString;
},
""
)
: "";
};
objectToQueryString()
函数的示例用法:
objectToQueryString({ page: "1", size: "2kg", key: undefined }); // 返回 '?page=1&size=2kg'
恭喜你!你已经完成了“将对象转换为查询字符串”实验。你可以在 LabEx 中练习更多实验来提升你的技能。