最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 22:10:18
文档

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

原生JS实现$.param() 函数的方法:由于遇到相关序列化的问题,但是vue项目中由于减少队jquery引用的,导致不能用$.param来序列化参数,所以写了如下方法用来解决相关问题,但由于考虑不全,可能存在判断不全或者代码冗余等情况,希望多提意见,多多改善 var personObj = { n
推荐度:
导读原生JS实现$.param() 函数的方法:由于遇到相关序列化的问题,但是vue项目中由于减少队jquery引用的,导致不能用$.param来序列化参数,所以写了如下方法用来解决相关问题,但由于考虑不全,可能存在判断不全或者代码冗余等情况,希望多提意见,多多改善 var personObj = { n


由于遇到相关序列化的问题,但是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() 函数的方法:由于遇到相关序列化的问题,但是vue项目中由于减少队jquery引用的,导致不能用$.param来序列化参数,所以写了如下方法用来解决相关问题,但由于考虑不全,可能存在判断不全或者代码冗余等情况,希望多提意见,多多改善 var personObj = { n
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top