小程序流程制做指南_原生JS完成$.param() 函数的方

摘要: 原生态JS完成$.param() 涵数的方式 本文关键详细介绍了原生态JS完成$.param() 涵数的方式,因为碰到有关编码序列化的难题,可是vue新项目中因为降低队jquery引入的限定,造成不可以...

原生JS实现$.param() 函数的方法       这篇文章主要介绍了原生JS实现$.param() 函数的方法,由于遇到相关序列化的问题,但是vue项目中由于减少队jquery引用的限制,导致不能用$.param来序列化参数,下面小编给大家分享了实例代码,需要的朋友参考下吧

由于遇到相关序列化的问题,但是vue项目中由于减少队jquery引用的限制,导致不能用$.param来序列化参数,所以写了如下方法用来解决相关问题,但由于考虑不全,可能存在判断不全或者代码冗余等情况,希望多提意见,多多改善

var personObj = {
 name:'cheny0815',
 age:24,
 c:[{
 id:1,
 name:2
 id:2,
 name:3
 other:{
 a:1,
 c:2,
 a:1,
 e:1,
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() 函数,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对凡科网站的支持!




联系我们

全国服务热线:4000-399-000 公司邮箱:343111187@qq.com

  工作日 9:00-18:00

关注我们

官网公众号

官网公众号

Copyright?2020 广州凡科互联网科技股份有限公司 版权所有 粤ICP备10235580号 客服热线 400-000-8888