jquery - 将 ViewModel 对象作为 Json 对象传递给 View

标签 jquery json asp.net-mvc-5

我尝试将 ViewModel 对象作为 Json 对象传递以进行查看。

InquiryOrderViewModel

public class InquiryOrderViewModel
{
    public InquiryOrder InquiryOrder { get; set; }        
}

InquiryOrder 模型

public class InquiryOrder
{
    [Key]
    public int InquiryOrderId { get; set; }

    public string InquiryOrderName { get; set; }

    [ForeignKey("ProductType")]
    public int ProductTypeId { get; set; }
    public virtual ProductType ProductType { get; set; }
}

InquiryOrderIndex View 和检索 Json 对象的脚本

@model eKnittingData.InquiryOrderViewModel

@using (Ajax.BeginForm("Save", "InquiryOrder", new AjaxOptions { UpdateTargetId = "IoResult", OnSuccess = "ajaxSuccess" }))
{
    @Html.TextBoxFor(a => a.InquiryOrder.InquiryOrderName)
    @Html.DropDownListFor(a => a.InquiryOrder.ProductTypeId, (SelectList)ViewBag.ProductTList, "Select")

    <input type="submit" value="Save" name="saveProp" class="btn btn-success" />
}

<script>
        $(document).on('click', '.myUpdateLink', function (e) {
            e.preventDefault();
            var inqOrdId = $(this).data('id');
            $.ajax({
                url: '@Url.Action("getForUpdate", "InquiryOrder")',
                type: "GET",
                dataType: "JSON",
                data: { InquiryOrderId: inqOrdId },
                success: function (io) {
                    alert("Successfully came from controller");
                    //How should i access elements in 'io'
                }
            }); 
        });
        </script>
Controller 中的

JsonResult

public JsonResult getForUpdate(int InquiryOrderId)
    {
        var objContext = new KnittingdbContext();

        var inquiryOrderViewModel = new InquiryOrderViewModel();
        var inquiryOrderObj = (InquiryOrder)objContext.InquiryOrders.Where(a => a.InquiryOrderId == InquiryOrderId).FirstOrDefault();
        inquiryOrderViewModel.InquiryOrder = inquiryOrderObj;

        return Json(new { io = inquiryOrderViewModel }, JsonRequestBehavior.AllowGet);
    }

alert("成功来自 Controller ") 成功触发。但我无法访问它的 InquiryOrderViewModel 属性(例如:InquiryOrder 然后是 InquiryOrder 的属性)。我想要的是,访问该属性的值并将其与 InquiryOrderIndex view(InquiryOrderName,ProductTypeId) 绑定(bind)。感谢所有帮助。谢谢!

最佳答案

您传递回一个以名为 io 的属性命名的匿名对象,其中包含您的 View 模型,因此要在 ajax 成功回调中访问它,将是

success: function (io) {
    var name = io.io.InquiryOrder.InquiryOrderName;

但是您不应该将 View 模型传递回客户端,除非该 View 模型仅包含 View 中所需的属性(并且从您的注释中包含其他属性,包括数据模型)。 Json() 方法会序列化您的模型,因此您通过网络发送回的数据比您需要的多得多,因此会降低性能。相反,只发回您需要的内容

var order = (InquiryOrder)objContext.InquiryOrders.Where(a => a.InquiryOrderId == InquiryOrderId).FirstOrDefault();
var data = new { name = order.InquiryOrderName, product = order.ProductTypeId };
return Json(data, JsonRequestBehavior.AllowGet);

然后在 View 中设置文本框和下拉列表的值

success: function (data) {
    $('#InquiryOrder_InquiryOrderName').val(data.name);
    $('#InquiryOrder_ProductTypeId').val(data.product);
}

关于jquery - 将 ViewModel 对象作为 Json 对象传递给 View ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33776058/

相关文章:

javascript - 如何折叠所有没有设置表单输入值的div

java - 从 REST 客户端接收作为 Java 对象的响应

asp.net - 自定义错误消息 MVC

c# - 在 IIS Express 8 上启动 ASP.NET MVC 5 项目需要很长时间才能启动

javascript - 文本的悬停颜色更改

javascript - 通过 jQuery 搜索子字符串

javascript - 将 .ajaxComplete() 与另一个框架生成的 ajax 请求一起使用

c# - 在 C# 中从未知的 JSON 内容创建一个无序列表

php - Laravel 5.2 : Redraw DataTable is not working But ajax. 重新加载()正在工作

javascript - 如何使用模型绑定(bind)器将数据从表单+跨度值发布到数据库