我是从asp时代过来的程序员,那个时代如果你传一个name相同的多个表单元素到后台时,它会形成一个数组,你可以获取name就行了,
但是当jQuery1.4出来时就不一样了,它改变了规则,它默认加了[]符号到name后面,变成了name[].
{foo: ["bar", "baz"]}
会被序列化为 “foo[]=bar&foo[]=baz”.
在jQuery 1.3版里, {foo: ["bar", "baz"]}
会被序列化为 “foo=bar&foo=baz”.
用jQuery.ajaxSettings.traditional
进行全局切换,或者根据情况单独切换。
总共有3种方式可以切换到旧的序列化方式:
1 // 全局改变序列化方式 (使用旧的) 2 jQuery.ajaxSettings.traditional = true; 3 // 指定情况使用旧的序列化方式 4 jQuery.param( stuff, true ); 5 // 针对一个单独的Ajax请求使用旧的序列化方式 6 $.ajax({ data: stuff, traditional: true });
随着年龄的增加,好多年不用这种写法了,记忆也模糊了。。。
html 中是允许多个具有相同name属性的元素的
服务器端读取的常规做法是:
string name = Request.Params["txtName"];
得到的将是一串以逗号分割的字符串,当然你可以手动分割:
string[] nameParts = name.Split(',');
但是当每个 input 输入可能包含逗号的时候,通过逗号分割就会是错的。
如何解决?
在 Classic ASP 通过 Request 可以这样分别获取
<%
firstName = Request.Form("txtName")(1)
middleName = Request.Form("txtName")(2)
lastName = Request.Form("txtName")(3)
%>
在 ASP.NET HttpRequest 同样支持 Classic ASP Request 的用法,
string[] nameParts = Request.Params.GetValues("txtName");
string firstName = nameParts[0];
string middleName = nameParts[1];
string lastName = nameParts[2];
以上用法对于 GET/POST 方式提交都是适用的。
值得注意的是,用来存储 QueryString/Form/ServerVariables 的对象是 System.Collections.Specialized.NameValueCollection, 这是 Key/Value 型对象,它的特殊性在于,一个Key下可存储多个 Value。
越来越怀念 Classic ASP,ASP+ 将简单的HTTP裹得太严实,很多简单实用的用法逐渐被遗忘,漫天飞的 runat="server" 让诸多原始但精巧的 form 处理方式没有被传承下来....