前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JS处理函数将对象作为参数传递

JS处理函数将对象作为参数传递

作者头像
何处锦绣不灰堆
发布2020-05-29 09:38:46
6.9K0
发布2020-05-29 09:38:46
举报
文章被收录于专栏:农历七月廿一农历七月廿一

做项目的时候遇到一个不是很常见的问题,就是js函数传递参数的时候,我们一般是传递一个数字或者是一个字符串,但是当你的需求满足不了的时候,就需要将对象或者数组作为一个参数传递过去,这个时候怎么做呢,今天简单的说有一下:

先说一下我出现这个问题的环境,我在处理订单信息的时候,接口给的参数是所有的数据,所以这个时候我需要的是将所有的数据遍历出来,数据结构大概是这样的:

这个是典型的三层的json结构,所以遍历的难度是不大的,就是很容就遍历出错,我的需求当然不是说仅仅将这些数据遍历出来就可以了,我需要做的是将最里层的data拿到,作为对象传递过去,因为这是每一个订单的具体内容,也就是详情,所以需要明确的将data作为一个参数传递过去,废话不说了,看代码;

代码语言:javascript
复制
success: function(data) {
				var odata = data.model_list;
				for(var i = 0; i < odata.length; i++) {
					detalData = JSON.parse(odata[i].data);
					//console.info(typeof detalData);
					var str = '<a οnclick="detal_info(' +                         
                    JSON.stringify(detalData).replace(/\"/g, "'") + ')">' +
                    '</a>'
					$('#order-detail').append(str);
}

这里简单的解释一下,首先拿到了成功的返回数据,这个时候我们看上面的数据结构,最外层的是model_list包括的,所以直接取出来,拿到以后呢将我们需要的data拿到,转为json格式的,这个时候我们下面需要用到里面数据的时候就比较容易拿到,下一步就是怎么将对象data作为一个参数传递过去,我们需要这样处理一下:

代码语言:javascript
复制
JSON.stringify(detalData).replace(/\"/g, "'")

将我们拿到的json对象转为string的字符串,然后用正则表达式将里面所有的''转为"",这样下面接收的时候才是可以的。、

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-12-01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档