/**
* 每日一題
* 基本的數組序列化功能, 【jQuery.param 簡單實現】
* @param {Array<{name,value}>} arr 待序列化的原數組
* @return {string} 返回一個序列化后字符串
*/
function param (arr) {
var str = '';
// TODO
if (Array.isArray(arr)) {
str = arr.map(function (item) {
return item.name + '=' + item.value;
}).join('&');
}
else {
str = param(obj2arr(arr));
}
return str;
}
/**
* 非序列化數組對象轉化為數組
* @param {a: 1, b: [2, 3]} obj 對象
* @return {[{name: 'a', value: 1}, {name: 'b', value: 2}, {name: 'b', value: 3}]} 序列化數組
*/
function obj2arr (obj) {
var arr = [];
Object.keys(obj).forEach(function (k) {
if (Array.isArray(obj[k])) {
arr = arr.concat(obj[k].map(function (v) {
return {
name: k,
value: v
};
}));
}
else {
arr.push({
name: k,
value: obj[k]
});
}
});
return arr
}
// Example:
var arr = [
{
name: 'a',
value: 1
},{
name: 'a',
value: 2
},{
name: 'b',
value: 'abc'
},{
name: 'c',
value: 'xxx'
},{
name: 'a',
value: 1
}
];
var obj1 = {
a: 1,
b: 'abc',
c: 'xxx'
};
var obj2 = {
a: [1, 2, 1],
b: 'abc',
c: 'xxx'
};
console.log( param(arr) ); // 'a=1&a=2&b=abc&c=xxx&a=1'
console.log( param(obj1) ); // 'a=1&b=abc&c=xxx'
console.log( param(obj2) ); // 'a=1&a=2&a=1&b=abc&c=xxx'
基本的數組序列化功能
最后編輯于 :
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
- 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
- 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
- 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
推薦閱讀更多精彩內容
- 轉換流 輸入字節流的轉換流:InputStreamReader 是字節流通向字符流的橋InputStreamRea...
- 以下為付偉2017年5月19日在第九屆CEFE春季峰會上的分享內容,與現場實錄略有增減。 各位同仁,大家早上好!感...