繁体   English   中英

需要从viewdata中选择最后一个ID

[英]Need to select last ID from a viewdata

我有一个带有生产订单的ViewData。 我做的事情是操作员可以通过选择他想要的生产订单来创建新的生产,但理想的是显示已经创建的最后生产订单,而不是他必须查看所有选项并选择最后一个一。 有人可以帮我吗?

我正在使用ASP-NET C#Razor Pages。

这是我的ViewData

 ViewData["production_order_ID"] = new SelectList(_context.Production_Order, "production_order_ID", "production_order_ID");

这是我的页面

<div class="col-md-2" style="margin-top:10px">
                <label asp-for="Production.production_order_ID" class="control-label">Ordem de Produção:</label>
                <select id="orderList" name="ids" asp-for="Production.production_order_ID" class="form-control" asp-items="ViewBag.production_order_ID" onchange="getSensors(); myFunction(event);"></select>
            </div>

现在显示ViewData上的第一项,但我需要默认显示最后一项。

一种方法是使用viewmodel:

public class OrdersViewModel
{
    public List<Order> Orders { get; set; }

    public int Selected { get; set; }
}

然后在你的action方法中创建,popullate并将viewmodel传递给视图:

public IActionResult Index()
{
    var orders = new List<Order>
    {
        new Order { OrderId = 1, OrderName = "Order # 1" },
        new Order { OrderId = 2, OrderName = "Order # 2" }
    };

    var viewModel = new OrdersViewModel() {
        Orders = orders,
        Selected = orders.LastOrDefault().OrderId    // get last order
    };

    return View(viewModel);
}

并且观点:

@model MyWebApplication.Models.OrdersViewModel   // use your namespace

<div class="col-md-2" style="margin-top:10px">
    <label class="control-label">Ordem de Produção:</label>
    <select id="orderList" name="ids" asp-for="@Model.Selected" class="form-control" asp-items="@(new SelectList(Model.Orders, "OrderId", "OrderName"))" onchange="getSensors(); myFunction(event);"></select>
</div>

所以基本上我刚刚做的是

ViewData["production_order_ID"] = new SelectList(_context.Production_Order.Where(c => c.User.AspNetUser.UserName.Equals(User.Identity.Name)).OrderByDescending(c => c.production_order_ID).ToList(), "production_order_ID", "production_order_ID");

并为我的意图工作得很好。 很抱歉浪费你的时间,但非常感谢你的回答。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM