1

我的 JsonResult 部分是真的吗?[HttpGet] 是否可能是 ActionResult 而 [HttpPost] 可能是 JsonReult?并且有不同的名字?我认为我的控制器错了。它不起作用。

我的控制器:

   [HttpGet]
    public ActionResult Customer()
    {
        var obj = new Project.Models.CentricModelClasses.ViewModelX();
        return PartialView(obj);
    }

    [HttpPost]
    public JsonResult Save(ViewModelX jsonMyModel)
    {
        var result = true;

        if (ModelState.IsValid)
        {

          result= MyClass.Insert (jsonMyModel.Address, jsonMyModel.Cod,
                jsonMyModel.idpurchase,
                jsonMyModel.idspend, jsonMyModel.Lname,
                jsonMyModel.Name, jsonMyModel.Tell, jsonMyModel.username);

        }
        else
        {

        }

        return Json(result, JsonRequestBehavior.AllowGet);

我的课 :

     public class ViewModelX
     {
    public Nullable< long > idpurchase { get; set; }
    public Nullable<long> idspend { get; set; }
    public string username { get; set; }
    public string Name { get; set; }
    public string Lname { get; set; }
    public string Tell { get; set; }
    public string Address { get; set; }
    public string CodPosti { get; set; }

    }

局部视图:

    @Html.HiddenFor(m => m.username)
    @Html.HiddenFor(m => m.Tell)
    @Html.HiddenFor(m => m.Name)
    @Html.HiddenFor(m => m.Mobil)
    @Html.HiddenFor(m => m.Lname)
    @Html.HiddenFor(m => m.id_purchase)
    @Html.HiddenFor(m => m.id_spend) 

   <script type="text/javascript">

$("#submit-btn2").click(function () { saveMyModel();});

function SaveMyModel()
{
    var e = document.getElementById("id_purchase");
    var str = e.options[e.selectedIndex].value;

    var e2 = document.getElementById("id_spend");
    var str2 = e.options[e.selectedIndex].value;

    $.ajax({
        url: '@Url.Action("Save", "Home")',
        type: 'POST',
        contentType: 'application/json',
        data: JSON.stringify({
            jsonMyModel: {

                username: $(".tdBuyername").val(),
                Tell: $(".tdPhone").val(),
                Name: $(".tdRecievername").val(),
                Mobil: $(".tdMobile").val(),
                Lname: $(".tdLname").val(),

                id_purchase: $("# id_purchase ").val(str),
                id_spend: $("# id_spend ").val(str2),
            }

            })
    });
}

4

1 回答 1

0

我认为您的问题是您正在使用的 jQuery 选择器。这 (username: $(".tdBuyername").val(),正在使用类选择器,因此将查找具有类的任何元素tdBuyername。很可能您实际上想要 id 或 name。

ID -$("#tdBuyername").val()

姓名 -$("[name=tdBuyername]").val()

还要确保您的 JSON 对象属性名称与您尝试绑定的模型匹配。egidpurchase不会被id_purchase回发的属性填充。

但是,对于您提出的另一个问题,关于您的保存方法是否正确,我想说它需要一些小的改进。也许是这样的:

[HttpPost]
public JsonResult Save(ViewModelX jsonMyModel)
{
    var result = false; //default to false in case Model isn't valid

    if (ModelState.IsValid)
    {
      result= MyClass.Insert (jsonMyModel.Address, jsonMyModel.Cod,
            jsonMyModel.idpurchase,
            jsonMyModel.idspend, jsonMyModel.Lname,
            jsonMyModel.Name, jsonMyModel.Tell, jsonMyModel.username);
    }

    return Json(result);
}
于 2013-09-09T21:30:23.240 回答