如何在mvc4中使用json返回多个参数?

时间:2016-03-05 13:47:45

标签: c# jquery json ajax asp.net-mvc-4

您好我的观点中有四个字段CustomerNameContactPersonEmailMobileNo

CustomerNameContactPerson为级联下拉列表,EmailMobileNo为文本框。

如果我选择CustomerName相关的ContactPerson将自动加载ContactPerson下拉列表。

如果我选择Contactperson ContactPerson相关EmailPhoneNo将自动加载到EmailPhoneNo文本框中。我完全完成了所有任务,一切正常。现在我需要的是我希望减少代码。

我的控制器代码

    public JsonResult GetCustomers()
     {
        return Json(db.Customers.ToList(), JsonRequestBehavior.AllowGet);
     }

    public JsonResult GetContactPersobByCustomerId(string customerId)
    {
        Guid Id = Guid.Parse(customerId);
        var customercontacts = (from a in db.CustomerContacts where a.CustomerID == Id select a);
        return Json(customercontacts, JsonRequestBehavior.AllowGet);
    }

  public JsonResult GetEmailByContactPersonID(Guid CustomerContactId)
     {
      var ContactID = db.CustomerContacts.Where(i => i.CustomerContactID == CustomerContactId).Select(i => i.ContactID).FirstOrDefault();
      var contact1 = (from p in db.Contacts where p.ContactID == ContactID select p).FirstOrDefault().Email1;
        if (contact1 == null)
        {
            var contact2 = (from a in db.Contacts where a.ContactID == ContactID select a).FirstOrDefault().Email2;
            contact1 = contact2;
        }
        return Json(contact1, JsonRequestBehavior.AllowGet);
     }

 public JsonResult GetPhoneNoByContactPersonID(Guid CustomerContactId)
    {
        var ContactID = db.CustomerContacts.Where(i => i.CustomerContactID == CustomerContactId).Select(i => i.ContactID).FirstOrDefault();
        var mobile1 = (from pn in db.Contacts where pn.ContactID == ContactID select pn).FirstOrDefault().Mobile1;
        if (mobile1 == null)
        {
            var mobile2 = (from a in db.Contacts where a.ContactID == ContactID select a).FirstOrDefault().Mobile2;

            mobile1 = mobile2;
        }
        return Json( mobile1, JsonRequestBehavior.AllowGet);
    }

我的观看代码

   @Html.Label("Customer Name", new { @class = "control-label" })
   @Html.DropDownListFor(model => model.CustomerID, new SelectList(string.Empty, "Value", "Text"), "Please select a Customer", new { @class = "form-control required", type = "text" })

   @Html.Label("Contact Person", new { @class = "control-label" })
   @Html.DropDownListFor(model => model.CustomerContactID, new SelectList(string.Empty, "Value", "Text"), "Please select a ContactPerson", new { @class = "form-control", type = "text", id = "CustomerContactID" })

   @Html.LabelFor(model => model.MobileNo, new { @class = "control-label" })
   @Html.TextBoxFor(model => model.MobileNo, new { @class = "form-control", type = "text",disabled = "disabled", @readonly = "readonly"  })
   @Html.ValidationMessageFor(model => model.MobileNo)

    @Html.LabelFor(model => model.Email, new { @class = "control-label" })
    @Html.TextBoxFor(model => model.Email, new { @class = "form-control", type = "text" ,disabled = "disabled", @readonly = "readonly" })
    @Html.ValidationMessageFor(model => model.Email)

我的Json代码

    <script src="~/Scripts/jquery-ui-1.11.0.js"></script>
   <script>
        $(function () {
      $.ajax(
        '@Url.Action("GetCustomers", "VisitorsForm")',{
            type: "GET",
            datatype: "Json",
            success: function (data) {
                $.each(data, function (index, value) {
                    $('#CustomerID').append('<option value="' + value.CustomerID + '">' + value.DisplayName + '</option>');
                });
            }
        });

          $('#CustomerID').change(function () {
        $('#CustomerContactID').empty();

        $.ajax(
           '@Url.Action("GetContactPersobByCustomerId", "VisitorsForm")',{
                type: "POST",
                datatype: "Json",
                data: { CustomerID: $('#CustomerID').val() },
                success: function (data) {
            $('#CustomerContactID').append($('<option></option>').val('').text('Please select'));
                    $.each(data, function (index, value) {
                 $('#CustomerContactID').append('<option value="' + value.CustomerContactID + '">' + value.ContactReference + '</option>');
                   });
                  }
               });
            });
        });

  $("#CustomerContactID").change(function () {
           alert("hhh");
    $.ajax(
        '@Url.Action("GetEmailByContactPersonID", "VisitorsForm")',{
            type: "GET",
            dataType: "json",
            async: false,
            data: { CustomerContactID: $("#CustomerContactID").val()
            },
            error: function (ex) {
                alert('Failed to retrieve Email.' + ex);
            },
            beforeSend: function () {
            },
            success: function (data) {
                $("#Email").val(data);
                             }
                         });
                     });

   $("#CustomerContactID").change(function () {
     alert("hhh");
    $.ajax(
        '@Url.Action("GetPhoneNoByContactPersonID", "VisitorsForm")',{
            type: "GET",
            dataType: "json",
            async: false,
            data: { CustomerContactID: $("#CustomerContactID").val()
            },
            error: function (ex) {
                alert('Failed to retrieve Email.' + ex);
            },
            beforeSend: function () {
            },
            success: function (data) {

                $("#MobileNo").val(data);
            }
          });
        });

请参阅我的编码,我单独写了json和jquery,EmailPhoneNo的ajax代码。我觉得这不好。我希望缩短我的代码。我想使用json传递多个参数。我想在Email下拉列表中选择phone时传递ContatcPersonContactPerson。它也会影响我的应用程序的性能。请任何人为我的问题提供解决方案和建议。

提前谢谢..

1 个答案:

答案 0 :(得分:0)

为什么不从控制器返回包含所需信息的对象?

序列化为Json的任何对象都可以作为JsonResult返回。

您甚至可以执行以下匿名类型:

var details = new { email = "test@test.com", phone = "1234567"};
return Json(details);