原生JS实现$.param() 函数的方法
程序员文章站
2022-04-29 17:31:19
由于遇到相关序列化的问题,但是vue项目中由于减少队jquery引用的限制,导致不能用$.param来序列化参数,所以写了如下方法用来解决相关问题,但由于考虑不全,可能存在...
由于遇到相关序列化的问题,但是vue项目中由于减少队jquery引用的限制,导致不能用$.param
来序列化参数,所以写了如下方法用来解决相关问题,但由于考虑不全,可能存在判断不全或者代码冗余等情况,希望多提意见,多多改善
var personobj = { name:'cheny0815', age:24, c:[{ id:1, name:2 },{ id:2, name:3 }], other:{ a:1, b:{ c:2, d:{ a:1, b:{ e:1, f:2 } } } }, } var nextstr = ''; function changedatatype(obj){ let str = '' if(typeof obj == 'object'){ for(let i in obj){ if(typeof obj[i] != 'function' && typeof obj[i] != 'object'){ str += i + '=' + obj[i] + '&' ; }else if (typeof obj[i] == 'object'){ nextstr = ''; str += changesontype(i, obj[i]) } } } return str.replace(/&$/g, ''); } function changesontype(objname, objvalue){ if(typeof objvalue == 'object'){ for(let i in objvalue){ if(typeof objvalue[i] != 'object'){ let value = objname + '[' + i + ']=' + objvalue[i]; nextstr += encodeuri(value) + '&'; }else{ changesontype(objname + '[' + i + ']', objvalue[i]); } } } return nextstr; } var resultparam = $.param(personobj); var resultmyself = changedatatype(personobj); document.write('resultmyself===>' + resultmyself + '<br><hr>') document.write('resultparam ===>' + resultparam + '<br><hr>') document.write('resultmyself === resultparam ===>' + (resultmyself === resultparam))
结果如下:
总结
以上所述是小编给大家介绍的原生js实现$.param() 函数,希望对大家有所帮助