:
let obj = {
a: 'hello',
b: {
b1: 'my',
b2: 'friend',
b3: {
c: 90
}
}
}
function getQueryString(obj, encode) {
function getPathToObj(obj, path = []) {
let result = [];
for (let key in obj) {
if (!obj.hasOwnProperty(key)) return;
//deep copy
let newPath = path.slice();
newPath.push(key);
let everyPath = [];
if (typeof obj[key] === "object") {
everyPath = getPathToObj(obj[key], newPath);
} else {
everyPath.push({
path: newPath,
val: obj[key]
});
}
everyPath.map((item) => result.push(item))
}
return result;
}
function composeQueryString(paths) {
let result = "";
paths.map((item) => {
let pathString = "";
if (item.path.length > 1) {
pathString = item.path.reduce((a, b, index) => {
return a + '['+ b +']';
})
} else {
pathString = item.path[0];
}
if (result) {
pathString = "&" + pathString + '=' + item.val;
} else {
pathString = "?" + pathString + '=' + item.val;
}
result += pathString;
});
return result;
}
const str = composeQueryString(getPathToObj(obj));
return encode === true ? encodeURI(str) : str;
}
console.log(getQueryString(obj, true));
GET:?=こんにちは& B%5Bb1%5D =私の& B%5Bb2%5Dは=友人& B%5Bb3%5D%5BC%5D = 90
どういう意味ですか?私は実装を追加しませんでした。私は実装を求めています。また、私が提供したURLはコード化されていると信じています。 http://www.freeformatter.com/url-parser-query-string-splitter.htmlを見て、URLを貼り付けて見てください。 –
私が言っていることは、あなたが作ろうとしている実装は、ファンキーなエッジケースに注意を払い、適切なテストスイートを持っている既存のモジュールよりもずっと悪くなってしまう可能性が高いということです。 –
ああ、ライブラリを使用するだけです –