欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

原生JS实现$.param() 函数的方法

程序员文章站 2022-10-08 11:56:01
由于遇到相关序列化的问题,但是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() 函数的方法

原生JS实现$.param() 函数的方法

总结

以上所述是小编给大家介绍的原生js实现$.param() 函数,希望对大家有所帮助