我正在创建一个.Net web服务来接收和处理来自JQuery.form.js的序列化表单数据,其中包含了表单中包含的几个多选择。
发送到webservice的序列化数据包括如下内容:
&travelwith=4&travelwith=5&travelwith=6对于字段'travelwith‘来说,在表单的select字段中,10项中有3项可供选择。
例如,我可以构造一个强类型化的类吗?
public class StoreUserSet
{
public Array travelwith { get; set; }
public string otherfield { get; set; }
....
}然后让我的web方法得到这样的对象:
StoreUserSet StUserSet = new StoreUserSet(); // Create new class instance.
[WebMethod()]
public bool ProfSet1(StoreUserSet StUserSet)
{
...
}会不会将多选择字段'travelwith‘的各种值自动解析到类的数组遍历中,以便我可以通过LINQ将3项值作为逗号分隔列表保存到SQL中?
我还没到这个地步..。我想我会得到关于我计划的方法的反馈。
谢谢你的反馈马丁。
发布于 2012-08-07 07:48:15
好的,由于我的KeyLargo站点的JQuery表单包含单个选择表单数据和多个选择,所以我需要能够将多个选择存储在Sql中的单个字段中。
我遇到了一些问题,试图使用Array类型来处理服务器上的多个选择,将数据存储在带有逗号分隔字符串的Sql单个字段中。因此,解决上述问题的方法是使用string[]创建强类型类,以捕获通过AJAX传递给服务器的序列化多选择数据:
public class StoreUserSet
{
public string[] travelwith { get; set; }
public string otherfield { get; set; }
....
}我使用Rick的便捷方法来处理从客户端传递的多选择数组数据:
public static string[] FormMultiple(this NameValue[] formVars, string name)
{
var matches = formVars.Where(nv => string.Equals(nv.name, name,
StringComparison.OrdinalIgnoreCase)).Select(nv => nv.value).ToArray();
return (0 == matches.Length) ? null : matches;
}要迭代数组设置值,如下所示:
profile_travelwith = formVars.FormMultiple("profile_travelwith");然后加入多选择string[]数组中的值,如下所示:
profile_travelwith = string.Join(",", StUserSet.profile_travelwith);可以轻松地将数据保存到配置文件的相关表字段中。
https://stackoverflow.com/questions/11729733
复制相似问题