将对象转换为查询字符串

JavaScriptJavaScriptBeginner
立即练习

This tutorial is from open-source community. Access the source code

💡 本教程由 AI 辅助翻译自英文原版。如需查看原文,您可以 切换至英文原版

简介

在本实验中,我们将探索如何使用 JavaScript 从对象的键值对生成查询字符串。我们将在 Object.entries() 上使用 Array.prototype.reduce() 方法来创建查询字符串,并根据 queryString 的长度确定要使用的合适符号。在本实验结束时,你将能够为你的 Web 应用程序高效地生成查询字符串。


Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL javascript(("`JavaScript`")) -.-> javascript/BasicConceptsGroup(["`Basic Concepts`"]) javascript(("`JavaScript`")) -.-> javascript/AdvancedConceptsGroup(["`Advanced Concepts`"]) javascript/BasicConceptsGroup -.-> javascript/variables("`Variables`") javascript/BasicConceptsGroup -.-> javascript/data_types("`Data Types`") javascript/BasicConceptsGroup -.-> javascript/arith_ops("`Arithmetic Operators`") javascript/BasicConceptsGroup -.-> javascript/comp_ops("`Comparison Operators`") javascript/BasicConceptsGroup -.-> javascript/obj_manip("`Object Manipulation`") javascript/AdvancedConceptsGroup -.-> javascript/higher_funcs("`Higher-Order Functions`") javascript/AdvancedConceptsGroup -.-> javascript/destr_assign("`Destructuring Assignment`") javascript/AdvancedConceptsGroup -.-> javascript/template_lit("`Template Literals`") subgraph Lab Skills javascript/variables -.-> lab-28524{{"`将对象转换为查询字符串`"}} javascript/data_types -.-> lab-28524{{"`将对象转换为查询字符串`"}} javascript/arith_ops -.-> lab-28524{{"`将对象转换为查询字符串`"}} javascript/comp_ops -.-> lab-28524{{"`将对象转换为查询字符串`"}} javascript/obj_manip -.-> lab-28524{{"`将对象转换为查询字符串`"}} javascript/higher_funcs -.-> lab-28524{{"`将对象转换为查询字符串`"}} javascript/destr_assign -.-> lab-28524{{"`将对象转换为查询字符串`"}} javascript/template_lit -.-> lab-28524{{"`将对象转换为查询字符串`"}} end

将对象转换为查询字符串

要将对象转换为查询字符串,请使用 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 中练习更多实验来提升你的技能。

您可能感兴趣的其他 JavaScript 教程