asp.net中mvc使用ajax提交参数的匹配问题解决探讨

  次阅读 来源:互联网(转载协议) 2016-01-27 15:17 我要评论(0)

本文为大家介绍下使用javaScript解决asp.net中mvc使用ajax提交参数的匹配问题,遇到类似情况的朋友可以参考下,希望对大家有所帮助

想到在asp.net的mvc中如果使用ajax向服务端传递参数时如果参数是一个类或者是个数组(或 List集合)以及更复杂的对象时,服务端总是会发 生取不到值的情况,当然网上也有很多解决的例子,但都是在服务端想办法来解决的(比如将json转换为字符串,再在服务端反序列化为一个对象),为何不能 在客户端就把这个问题搞定。

其实问题没那么复杂,那是因为在jquery提交Array的数据时,提交的时候始终会在名称后面加上[] , 问题就出在这里。另外在服务端对数组和内嵌的js对象进行解析时,需要像这样的格式,比如数组(或List集合)在服务端需要这样 {'xxx[0]':'aaa','xxx[1]':'bbb'}的格式,而内嵌对象需要像这样 {'xxx.a':'ddd','xxx.b':'hhh'},找到问题的原因就好解决了,如果我们能将json的格式转换为服务端了能够识别的格式,问 题岂不迎刃而解。

说干就干,直接上代码

复制代码 代码如下:

//用于MVC参数适配JavaScript闭包函数

/*

使用方式如下:

$.ajax({

url: "@Url.Action("AjaxTest")",

data: mvcParamMatch("", sendData),//在此转换json格式,用于mvc参数提交

dataType: "json",

type: "post",

success:function(result) {

alert(result.Message);

}

});

*/

var mvcParamMatch = (function () {

var MvcParameterAdaptive = {};

//验证是否为数组

MvcParameterAdaptive.isArray = Function.isArray || function (o) {

return typeof o === "object" &&

Object.prototype.toString.call(o) === "[object Array]";

};

//将数组转换为对象

MvcParameterAdaptive.convertArrayToObject = function (/*数组名*/arrName, /*待转换的数组*/array, /*转换后存放的对象,不用输入*/saveOjb) {

var obj = saveOjb || {};

function func(name, arr) {

for (var i in arr) {

if (!MvcParameterAdaptive.isArray(arr[i]) && typeof arr[i] === "object") {

for (var j in arr[i]) {

if (MvcParameterAdaptive.isArray(arr[i][j])) {

func(name + "[" + i + "]." + j, arr[i][j]);

} else if (typeof arr[i][j] === "object") {

MvcParameterAdaptive.convertObject(name + "[" + i + "]." + j + ".", arr[i][j], obj);

} else {

obj[name + "[" + i + "]." + j] = arr[i][j];

}

}

} else {

obj[name + "[" + i + "]"] = arr[i];

}

}

}

func(arrName, array);

return obj;

};

//转换对象

本站部分文章来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 品友互动为Digital Travel APAC2018 唯一受邀中国AI企业

    品友互动为Digital Travel APAC2018 唯一受邀中国AI企业

  • 第一批国家重点研发计划公布,旷视科技开启“五年行动”

    第一批国家重点研发计划公布,旷视科技开启“五年行动”

  • 长虹新款智能语音空调,告诉你空调也能玩Siri

    长虹新款智能语音空调,告诉你空调也能玩Siri

  • 让AI触手可及  Qualcomm携手创通联达推出全新终端侧AI开发套件

    让AI触手可及 Qualcomm携手创通联达推出全新终端侧AI开发套件

网友点评网友点评
阅读推荐阅读推荐

据外媒报道,STEER打造了首款完全自动驾驶停车技术,旨在使常规车辆转变为无人驾驶车辆。STEER的首款技术应用是4级自动驾驶及网络安全停车...

近日,美国软性机器抓手制造商 Soft Robotics 宣布,获得 2000 万美元的融资,本轮投资者包括 Scale Venture Partners,Calibrate Ventures...

据外媒报道,加州车管局发布了《2017自动驾驶脱离报告(California Autonomous Vehicle Disengagement Reports)》,其中谈及了脱离的具体...

用人机语音交互,来解决智能家居适老的问题;通过家庭门禁与安防套件、空气净化套件、可燃气体与有害气体监控套件等相互联动,在不同生活情...