1

我不知道为什么会发生这种情况,我已经设置了值并对其进行了调试,但它只是没有将信息从控制器传递到视图。这是发生了什么

模型:

public class QueueFilterModel
{
    public string SelectedFilter { get; set; }
    public string query { get; set; }
    public List<string> MyFilterList { get; set; } 


}

控制器:

[HttpGet]
    public ActionResult Queue()
    {
        QueueFilterModel model = new QueueFilterModel()
        {
            SelectedFilter = "All",
            query = "SELECT * FROM [CHAVI].[dbo].[TicketQueue]",
            MyFilterList = new List<string>()

        };
        model.MyFilterList.Add("All");
        model.MyFilterList.Add("Open");
        model.MyFilterList.Add("Closed");


        return View();
    }

看法:

@model RazorARPP.Models.QueueFilterModel
@{
ViewBag.Title = "Queue";
}

<h2>Queue</h2>


    <form action="" method="post" enctype="multipart/form-data" id="MyForm">

        Filter
        <div>
            Filter Options:
        </div>
        <div>
            @Html.DropDownList("test", new SelectList(Model.MyFilterList,Model.SelectedFilter))
        </div>


            <h3>Insert Instructions Here</h3>
                @{
                    var DB = Database.Open("CHAVI");
                    var grid = new WebGrid(DB.Query("SELECT * FROM [TicketQueue]"), null, null, 20);

                    @grid.GetHtml(
                        tableStyle: "webgrid",
                        columns: grid.Columns(
                        grid.Column(header: "Link", style: "labelcolumn", format: (item) => Html.ActionLink("Edit Item", "EditQueue", new { id = item.QueueID})),
                        grid.Column("Description", "Description"),
                        grid.Column("QueueDate", "QueueDate"),
                        grid.Column("Note", "Note"),
                        grid.Column("Status", "Status"),
                        grid.Column("LastUpdated", "LastUpdated")
                            )
                    )
                 }
    </form>

网格部分工作正常(和查询)。问题出在下拉列表中,那里没有设置任何内容。有什么想法吗?谢谢。

4

2 回答 2

1

您不是将模型传递给查看吗?

不应该

public ActionResult Queue()
    {
        QueueFilterModel model = new QueueFilterModel()
        {
            SelectedFilter = "All",
            query = "SELECT * FROM [CHAVI].[dbo].[TicketQueue]",
            MyFilterList = new List<string>()

        };
        model.MyFilterList.Add("All");
        model.MyFilterList.Add("Open");
        model.MyFilterList.Add("Closed");


        return View(model);
    }
于 2012-12-14T15:15:50.323 回答
0

尝试使用:-

public ActionResult Queue()
{
    QueueFilterModel model = new QueueFilterModel()
    {
        SelectedFilter = "All",
        query = "SELECT * FROM [CHAVI].[dbo].[TicketQueue]",
        MyFilterList = new List<string>()

    };
    model.MyFilterList.Add("All");
    model.MyFilterList.Add("Open");
    model.MyFilterList.Add("Closed");


    return View(model);
} 
于 2012-12-14T15:16:54.927 回答