在 Jquery 中调用 ViewBag 从 controller 获取值

Call ViewBag in Jquery to get the value from controller

我打电话给 ViewBag.DeliveryDatebySupplier 是为了更新我的文本框或只是为了提醒。该值始终为 null。但是当我调试并检查控制器中的 ViewBag 时,它具有日期值。

控制器

if (ds.Tables[0].Rows.Count == 1)
{
    string dt = ds.Tables[0].Rows[0]["DeliveryDt"].ToString();
    DateTime myDate = Convert.ToDateTime(dt);
    dt =  myDate.ToString("yyyy-MM-dd");
    ViewBag.DeliveryDatebySupplier = dt.ToString();
    //Session["NewDeliveryDate"] = dt.ToString();                    
}

Jquery

function getDeliveryDateBySupplier() {
    var _storeID = $('#ddlStoreID :selected').val();
    var _SupplierID = $('#ddlSupplier :selected').val();

    var url = "@Url.Content("~/Home/DeliveryDatebySupplier")";

    $.ajax({
        data: {
             StoreID: _storeID,
             SupplierID: _SupplierID
        },
        type: 'POST',
        cache: false,
        dataType: 'json',
        url: url,
        success: function (result) {
            var newDeliveryDate = '@ViewBag.DeliveryDatebySupplier';
            alert(newDeliveryDate);
        },
        error: function (ex) {
            alert("Error getDeliveryDateBySupplier()");
        }
    });
}

假设在 HomeController 中调用 DeliveryDatebySupplier 的操作是设置 ViewBag.DeliveryDatebySupplier,那么不幸的是这将不起作用。

脚本将在生成完整页面时生成,那时还没有设置值。

我建议不要使用 viewbag,return 在脚本中调用 DeliveryDatebySupplier 时的值。

控制器将是这样的

    if (ds.Tables[0].Rows.Count == 1)
    {
    string dt = ds.Tables[0].Rows[0]["DeliveryDt"].ToString();
    DateTime myDate = Convert.ToDateTime(dt);
    dt =  myDate.ToString("yyyy-MM-dd");
    return new JsonResult
    {
        data = new
        {
            DeliveryDatebySupplier = dt.ToString()
        }
    };                     
    }

和jquery会变成这样

success: function (data) {
 if (data) {
    var newDeliveryDate = data.DeliveryDatebySupplier
    alert(newDeliveryDate);
}
else {
    //Error
}
},