MVC 3 Razor DropdownListFor - Как «фильтровать» представление после выбора значения - PullRequest
0 голосов
/ 18 января 2012

Поэтому я взял несколько советов по созданию в моем виде элемента DropDownListFor, что означало создание модельного представления под названием

MODEL
class StudentModelView.

У меня есть два свойства.

StudentID{get;set;}
IEnumerable<SelectListItem> SelectPeopleList { get;set;}

Я получаю список, чтобы красиво заполнить этот код

ПРОСМОТР

    @Html.DropDownListFor(x => x.StudentID, Model.SelectPeopleList,"--Select Students--", new Dictionary<string,object>{ {"class","dropdowns"},{"id","selectPeopleDDL"}})  

//NEED A BUTTON TO SUBMIT 

КОНТРОЛЛЕР

 public ActionResult Index()
        {


            return View(new StudentModelView());
        }  
  1. Какую кнопку мне нужно сделать, чтобы она отправила
  2. После публикации как мне обновить мой вид, чтобы показать новый отфильтрованный список? Я пропускаю POST-контроллер или просто AJAX? Какой лучший подход?

1 Ответ

1 голос
/ 18 января 2012

Вы можете сделать все это с помощью jquery, но вот пара указателей:

Вы должны обернуть свой фильтр в форму:

@using (Html.BeginForm("Home", "Index", FormMethod.Get))
{
  @Html.DropDownListFor(x => x.StudentID, Model.SelectPeopleList,"--Select Students--", new Dictionary<string,object>{ {"class","dropdowns"},{"id","selectPeopleDDL"}})
  <input type="submit" value="Go" />
}

кнопка отправки не обязательна, вы можете просто использовать jquery для отправки всякий раз, когда изменяется значение раскрывающегося списка

в вашем контроллере:

public ActionMethod Index(int? studentID)
{
  var model = new StudentModelView 
  {
    StudentId = studentID, 
    SelectPeopleList=GetListFiltered(studentId)  
  }

  return(model);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...