将前台input中的数据异步传到后台并存入数据库

将前台input中的数据异步传到后台并存入数据库

先看图:

《将前台input中的数据异步传到后台并存入数据库》

利用ajax异步交互数据,并不是以json数组的形式将数据传到后台,而是利用字符数组的形式将其传到后台。动态新增每一行数据,将每一列对应的数据存入数组,并传到后台中进行入库。(当然可以直接以json数组的形式将每一行的数据传到后台,这里就不详细讲了)

前台js代码:

  ///保存多行数据,运用ajax异步交互请求
        function btnSave() { /*传值方式一:将添加的每一字段的值存在数组中,再将数组转换成字符串串传到后台*/
            //定义五个一维数组
            var code = new Array(); var name = new Array(); var pwd = new Array(); var phone = new Array(); var bmmc = new Array(); //将表单中的数据添加到各自的数组中
            for (var i = 1; i <= rowL; i  ) { code.push($("#"   "UserCode"   i).val());//对应每个增加表单中的id相应的值
                name.push($("#"   "UserName"   i).val()); pwd.push($("#"   "UserPwd"   i).val()); phone.push($("#"   "Phone"   i).val()); bmmc.push($("#"   "Bmmc"   i).val()); } //利用js的join方法将数组分割成字符串,用于传值,在后台解析。分割符号为逗号,可自行定义。
            var Code = code.join(','); var Name = name.join(','); var Pwd = pwd.join(','); var Phone = phone.join(','); var Bmmc = bmmc.join(','); //利用ajax进行传值,类型为POST
 $.ajax({ type: "POST", // dataType: "Text",
                url: "UserList.ashx?Action=Save", data: { UserCode: Code, UserName: Name, UserPwd: Pwd, UserPhone: Phone, BmMc: Bmmc, RowLength: rowL//将增加的行数传至后台控制for循环中的参数范围
 }, success: function (result) { if (result == "true") { noty({ text: "保存成功!", type: "success", layout: "topCenter", timeout: 2000 }); Refresh(); } else { noty({ text: "保存失败!", type: "error", layout: "topCenter", timeout: 2000 }); } } }); }

2、后台获取数据的代码:

   private string HandleSaveRequest(HttpContext context) { string result = "False"; try { /*定义参数数组,获取前台数据,并解析成数组形式。运用方法split()*/
                string []UserName = context.Request.Form["UserName"].ToString().Split(','); string []UserCode = context.Request.Form["UserCode"].ToString().Split(','); string []UserPwd = context.Request.Form["UserPwd"].ToString().Split(','); string []Phone = context.Request.Form["UserPhone"].ToString().Split(','); string[] BmMc = context.Request.Form["BmMc"].ToString().Split(','); int  length =Int32.Parse( context.Request.Form["RowLength"].ToString()); DUserList user = new DUserList(); MUserList Muser = new MUserList(); //将数组中的数据遍历插入数据库
                for (int i = 0; i <length; i  ) { Muser.NVFID = System.Guid.NewGuid().ToString(); Muser.USERCODE = UserCode[i]; Muser.USERNAME = UserName[i]; Muser.USERPWD = UserPwd[i]; Muser.BMMC = BmMc[i]; Muser.PHONEIMEI = Phone[i]; // user.Insert(Muser);
                    if (user.Insert(Muser)) { result = "true"; } else { result = "False"; } } } catch(Exception ex) { } return result; }

注意:ajax不能直接将数组直接传递到后台,所以在数组传递之前用Join()方法将数组转换成字符串,在后台获取到字符串之后再用spit()方法进行分割成数组。

    原文作者:会做饭的技术男
    原文地址: https://blog.csdn.net/u011927449/article/details/104064397
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞