• js表单序列化


     

    原文链接

    做项目的过程中,表单是必不可少的,经常用来提供数据。为了获取表单数据,必须将字段的值逐个添加到参数中,如果表单的数据量非常大,不仅添加字段参数的过程无疑是痛苦的,而且表单也缺乏弹性。但是jquery中提供了一个很好的处理表单数据的函数——serialize();

      这个函数可以把表单中的值序列化为字符串。下面是net小伙的测试代码(主要功能:输入用户名和密码,并在下面的p中显示出来):

    前台界面设计如下:

    复制代码
    1 <form action="" id="form1">
    2     用户名:<input name="name" type="text" /><br />
    3     密 码:<input name="pass" type="text" /><br />
    4 
    5 </form>
    6     <input type="button" id="sub" value="提交" /> <br />
    7     <p id="result"></p>
    复制代码

    添加一个一般处理程序文件,代码如下:

    复制代码
    1         public void ProcessRequest(HttpContext context)
    2         {
    3             context.Response.ContentType = "text/plain";
    4             //context.Response.Write("Hello World");
    5             string username = context.Request["name"];
    6             string password = context.Request["pass"];
    7             context.Response.Write(username + password);
    8 
    9         }
    复制代码

    引用jquery库,然后编写javascript代码:

    复制代码
     1     <script type="text/javascript">
     2         $(function () {
     3             $("#sub").click(function () {
     4                 var rerial = $("#form1").serialize();
     5                 $.post("ashx/formlists.ashx", rerial, function (data, status) {
     6                     if (status == "success") {
     7                         $("#result").html(data);
     8                     }
     9                 });
    10 
    11             });
    12 
    13         });
    14     </script>
    复制代码

    需要注意的事项是:表单中的input必须有name这个属性,因为一般处理程序中请求参数是通过name属性来获取参数的值;net小伙在刚开始用了id这个属性,但是是了一天都没试出来。经测试发现得到的值总是空值,然后在W3C上看了一下使用方法,又对比了自己的代码,发现只有name属性缺少了,其他的都一样,然后添加了name属性就ok了!

    本人小白,博客作为在线笔记,若有错误,还望指出,转载链接截图等皆为学习,若有侵权,请告知,
  • 相关阅读:
    Yii2 框架目录
    实现超链接在本页面的跳转
    操作系统
    shell笔记
    软RAID5制作流程
    nginx学习之简化安装篇(一)
    Javascript中实现继承的方式
    JavaScript中的函数和C#中的匿名函数(委托、lambda表达式)
    JavaScript中变量、执行环境、作用域与C#中的异同
    Javascript与C#对变量的处理方式
  • 原文地址:https://www.cnblogs.com/xiaoxiaoyao/p/8575069.html
Copyright © 2020-2023  润新知