首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >URLSearchParams.set()没有URIEncoding

URLSearchParams.set()没有URIEncoding
EN

Stack Overflow用户
提问于 2022-03-02 00:36:03
回答 1查看 1K关注 0票数 0

URLSearchParams.set(键,值) URIEncodes给出的值,产生丑陋的未指定的urls。

下面的测试是基于这个url友好字符列表

代码语言:javascript
复制
const url = new URL("http://www.example.com/path");
const test = "abc123+-_$#%?@,"
url.searchParams.set("foo", test);

console.log(`What foo should be: ${test}`);
console.log(`What foo is: ${url.search}`)

是否有一种方法可以使用URL.searchParams 中的URLSearchParams来更新搜索参数,使其符合给定的值,而不是对其进行编码?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-03-02 00:47:04

如果一个人希望他们所有的searchParams都是未编码的,他们只需将url.search设置为一个未编码的自身版本:

代码语言:javascript
复制
const url = new URL("http://www.example.com/path");
const test = "abc123+-_$#%?@,"
url.searchParams.set("foo", test)
url.search = decodeURIComponent(url.search)

console.log(`What foo should be: ${test}`);
console.log(`What foo is: ${url.search}`)

如果只希望指定的密钥未编码,则需要额外的

代码语言:javascript
复制
const testUrl = new URL("http://www.example.com/path");
testUrl.searchParams.set("bar", "++ ++");

const testVal = "abc123+-_$#%?@,";
setValueUnencoded(testUrl, "foo", testVal);


console.log(`What foo should be: ${testVal}`);
console.log(`What foo is: ${testUrl.search}`)


function setValueUnencoded(url, key, value) {
  url.searchParams.set(key, value);
  const entries = Array.from(url.searchParams.entries());
  url.search = "";
  entries.forEach(item => {
    if (item[0] === key) { return; }
    url.searchParams.set(item[0], item[1]);
  });
  url.search += `${key}=${value}`;
}

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71316183

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档