使用js数组拼接json并post到contoller

原创 2017年07月10日 20:45:12

view:

<script type="text/javascript">

    var id = 0;
    var i = 1;
    var s = ["div1"];
    function add() {
        i++;
        var id = "div" + i.toString();
        s.push(id);
        var t = '<div id="div' + i.toString() + '" style="border: 1px dashed #F00;margin:10px" >' +
        '<input type="text" class="input-text" style="width: 180px;margin:5px" value="" name="test"/>' +
        '<input type="text" class="input-text" style="width: 180px;margin:5px" value="" name="test"/>' +
        '<input type="text" class="input-text" style="width: 180px;margin:5px;float:none;" value="" name="test" />' +
        '<input type="text" class="input-text" style="width: 180px;margin:5px" id="field_2" value="" name="test" />' +
            '<div style="background-image:url(/images/add.png);width:40px;height:40px;float:left" onclick="add()"></div>' +
            '<div style="background-image:url(/images/delect.png);width:40px;height:40px;float:right" onclick="remove(div' + i.toString() + ')"></div></div>';
        $(divList).append(t);
    }
    function remove(id) {
        id.parentNode.removeChild(id);
    }

    function article_save_submit() {

        var jsonstr = "";
        var a = [];
        var Pname = document.getElementById("txt_pjName").value;
        var PjCity = document.getElementById("txt_pjCity").value;
        var MachineNum = document.getElementById("txt_mchineNum").value;
        var IsNow = document.getElementById("select_IsNow").value;
        var PjXSName = document.getElementById("txt_PjXSName").value;
        var IsDealer = document.getElementById("txt_IsDealer").value;
        var Phone = document.getElementById("txt_phone").value;
        var Other = document.getElementById("txt_other").value;
        debugger
        var url = '@Url.Action("InserProject", "PreAdmin")';


        a.push({ 'Pname': Pname, 'PjCity': PjCity, 'MachineNum': MachineNum, 'IsNow': IsNow,'PjXSName': PjXSName, 'IsDealer': IsDealer, 'Phone': Phone, 'Other': Other })
        for (var i = 0; i < s.length; i++) {
            var divname = "#" + s[i] + "  input[type='text']";
            var x = 1;
            var PjName = "";
            var PjNum = "";
            var Xdd = "";
            var Xddw = "";
            $(divname).each(function () {
                if (x == 1) {
                    PjName = $(this).val();
                }
                if (x == 2) {
                    PjNum = $(this).val();
                }
                if (x == 3) {
                    Xdd = $(this).val();
                }
                if (x == 4) {
                    Xddw = $(this).val();
                }

                x++;

            });
            a.push({ 'PjName': PjName, 'PjNum': PjNum, 'Xdd': Xdd, 'Xddw': Xddw })
        }
        jsonstr = JSON.stringify(a);
        alert(jsonstr)

        var url = '@Url.Action("InserMachineInfo", "PreAdmin")';
        $.post(url, { jsonstr: jsonstr, id: id },
         function (istrue) {
         });
    }

controller(use ef) :

[HttpPost]
        public void InserMachineInfo(string jsonstr,int id)
        {
            //use json.net
            JArray o = (JArray)JsonConvert.DeserializeObject(jsonstr);
            IList<JToken> oList = (IList<JToken>)o;
            int proId=0;
            foreach (JToken jt in oList)
            {

                JObject jo = jt as JObject;
                using (var db = new TestTryEntities1())
                {
                    if (jt == o[0])
                    {
                        ProjectInfo pro = new ProjectInfo()
                        {
                            pname = jo["Pname"].ToString(),
                            pjCity = jo["PjCity"].ToString(),
                            machineNum = jo["MachineNum"].ToString(),
                            isNow = Convert.ToInt32(jo["IsNow"].ToString()),
                            pjXSName = jo["PjXSName"].ToString(),
                            isDealer = Convert.ToInt32(jo["IsDealer"].ToString()),
                            phone = jo["Phone"].ToString(),
                            other = jo["Other"].ToString(),
                            createtime = DateTime.Now,
                            fixtime = DateTime.Now
                        };
                        db.ProjectInfo.Add(pro);
                        db.SaveChanges();
                        proId = pro.id;
                    }
                    else 
                    {
                        machineinfo model = new machineinfo()
                        {
                            id = proId,
                            machineName = jo["PjName"].ToString(),
                            machineNum = Convert.ToInt32(jo["PjNum"].ToString()),
                            test = jo["Xdd"].ToString(),
                            other = jo["Xddw"].ToString(),
                            createtime = DateTime.Now,
                            fixtime = DateTime.Now

                        };
                        db.machineinfo.Add(model);
                        db.SaveChanges();
                    }

                }
            }
        }
版权声明:本文为博主原创文章,未经博主允许不得转载。

js传递数组到后台

js传递数组到后台
  • zhaohuijiadelu
  • zhaohuijiadelu
  • 2017年01月13日 14:31
  • 11181

ajax的post方式传数组参数

前端js代码: $("#btn-simple-submit").click(function () { var selectImportModule = $("[name='impor...
  • u011734144
  • u011734144
  • 2016年12月23日 11:06
  • 5823

ajax传递给后台数组参数方式

在项目上用到了批量删除与批量更改状态,前台使用了EasyUI的DataGrid,用到了批量更改数据状态功能。 在前台可以获取每条数据的ID,但是如何通过数组方式传递给后台? 通过昨晚的各种方式的调...
  • lingxyd_0
  • lingxyd_0
  • 2013年08月28日 10:11
  • 173001

js传递数组到后台

标红了哦,这个是关键
  • liu4071325
  • liu4071325
  • 2016年08月05日 10:28
  • 1261

WebForm页面间传值方法

Asp.NET WEB FORMS 给开发者提供了极好的事件驱动开发模式。Asp .NET为我们提供了三种方式,一种是可以通过用QueryString来传送相应的值,再一种是通过session变量来传...
  • llxlett
  • llxlett
  • 2013年01月17日 13:01
  • 2831

web 前后台数据交互的方式

做web开发,很重要的一个环节就是前后台的数据的交互,数据从页面提交到contoller层,数据从controler层传送到jsp页面来显示。这2个过程中数据具体是如何来传送的,是本节讲解的内容。 ...
  • walkingmanc
  • walkingmanc
  • 2012年05月25日 15:41
  • 61457

使用js数组拼接json并post到contoller

view: var id = 0; var i = 1; var s = ["div1"]; function add() { i++; ...
  • lz37025
  • lz37025
  • 2017年07月10日 20:45
  • 180

前后台交互之传参方式

行舟逆水 CnBlogsHomeNew PostContactAdminRss Posts - 17  Articles - 0  Comments - 0  ...
  • qq_37788728
  • qq_37788728
  • 2017年06月16日 10:05
  • 502

Android okhhtp post 提交参数拼接成json串

最近开发的过程中遇到后台需要把参数拼接成json串的方式提交,之前都没遇到过类似的问题,都是直接提交,上网搜索大多都没有直接的答案,经过几天的研究之后,做出来了,特意把代码贴出来记录一下,希望可以帮到...
  • sinat_32194985
  • sinat_32194985
  • 2017年09月06日 14:39
  • 235

Post 请求参数 数据装载. 生成JSON

Post 请求参数 数据装载 一、普通JSON数据装载 Activity: Map map = new HashMap(); map.put("storeCode", "12244"); re...
  • legend12300
  • legend12300
  • 2016年08月11日 14:04
  • 928
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:使用js数组拼接json并post到contoller
举报原因:
原因补充:

(最多只允许输入30个字)