0

我是 MVC 的新手,我想在我的观点上做两件事:

1 - 数据列表(3 列) 2 - 我可以过滤列表的下拉列表(填充第一列中的数据)

在我的控制器中,我具有以下功能:

public ViewResult ListUrl()
{
    var ws = new Service1();
    localhost.Service1 s1 = new Service1(); // data from web services
    localhost.UrlInfo[] ui = s1.GetUrlInfo();
    for (int i = 0; i < ui.Length; i++)
        {
            var UrlItem = new UrlItem();
            UrlItem.Id = Convert.ToInt32(ui[i].Id);
            UrlItem.urlll = ui[i].url;
            UrlItem.toontijd = ui[i].ToonTijd;
            UrlItem.positie  = Convert.ToInt32(ui[i].positie);

            Models.ListUrl.UrlList.Add(UrlItem);
        }

        var urlname = from url in s1.GetUrlInfo() select url  ;
        ViewData["url"] = new SelectList(urlname, "Id", "url");

    return View();

}

在视图中:

<script type="text/javascript">
$(document).ready(function () {

   // How can I filter the list (see <table> tag) when I change index of dropdown list???

});
</script>

@Html.DropDownList("SelectedItem", (SelectList)ViewData["url"], "----- all ------", new { id = "0", text = "----- all ------" })

<table>
<tr>
    <th>
        Url
    </th>
    <th>
        Toontijd
    </th>
    <th>
        Positie
    </th>
</tr>

@foreach (var item in ListUrl.UrlList)
{
    <tr>
        <td>
            @item.urlll.ToString()        
        </td>
        <td>
            @item.toontijd.ToString()

        </td>
        <td>

        </td>
        <td>
            @item.positie.ToString()
        </td>
    </tr>

}

如何使下拉列表更改事件起作用?非常感谢。

希查姆。

4

1 回答 1

1

好吧..您需要为此做一些事情..让我逐步解释..

  1. 为网格创建局部视图
  2. 为下拉菜单附加 onchange 事件
  3. 制作一种以下拉选择为参数并返回网格局部视图作为结果的控制器操作方法

    $.get('yourActionURL', { parameter: $('#yourDropdownId').val() }, function(result) {
        $('#grid').html(result);
    });
    

在 MVC4ASP.NET MVC 中使用 DropDownList 过滤 WebGrid 过滤会导致列表/网格- 这些链接可以帮助您详细了解这一点。

于 2013-07-03T13:25:04.043 回答