繁体   English   中英

在MVC3中发回时如何设置DropDown的默认值

[英]How to set the Default value for DropDown when post back in MVC3

我正在使用MVC3,并且有一个下拉列表,需要从数据库设置默认值。

当我在下拉列表中选择一个值时,我得到一个回发,并且即使在回发之后,也会选择我选择的值。 回发后如何再次获得默认值<-Select Project->作为选定值? 在MVC中如何完成?

以下是我使用的控制器和视图。

我的模特儿

namespace BugTracker.Models
{
    public class BugModel
    {
        public List<BugModel> InsertBug {get; set;}
        public List<BugModel> Bugs { get; set; }
        public Int16 BugID { get; set; }
        [Required(ErrorMessage = "Title is required")]
        public string Title { get; set; }
        [Required(ErrorMessage = "Description is required")]
        public string Description {get; set;}
        [Required(ErrorMessage = "Version is required")]
        public string Version { get; set; }
        [Required(ErrorMessage = "BuildNumber is required")]
        public string BuildNumber { get; set; }
        [Required(ErrorMessage = "CreatedDate is required")]
        public string CreatedDate { get; set; }
        [Required(ErrorMessage = "GetDate is required")]
        public string GetDate { get; set; }

        public List<BugModel> GetProjects { get; set; }
        public int ProjectID { get; set; }
        [Required(ErrorMessage = "ProjectName is required")]
        public string ProjectName { get; set; }

        public List<BugModel> GetEmployee {get; set;}
        public int EmployeeID { get; set; }
        public int CreatedByID { get; set; }
        [Required(ErrorMessage = "EmployeeName is required")]
        public string EmployeeName {get;set;}
        [Required(ErrorMessage = "CreatedBy is required")]
        public string CreatedBy { get; set; }

        public List<BugModel> GetCategory { get; set;}
        public int CategoryID { get; set; }
        [Required(ErrorMessage = "Category is required")]
        public string Category { get; set;}

        public List<BugModel> GetSeverity { get; set;}
        public int SeverityID { get; set; }
        [Required(ErrorMessage = "Severity is required")]
        public string Severity { get; set; }

        public List<BugModel> GetPriority { get; set; }
        public int PriorityID { get; set; }
        [Required(ErrorMessage = "Prirority is required")]
        public string Prirority { get; set;}

        public List<BugModel> GetReleasePhase { get; set;}
        public int ReleasePhaseID { get; set; }
        [Required(ErrorMessage = "ReleasePhase is required")]
        public string ReleasePhase { get; set;}

        public List<BugModel> GetTypes { get; set; }
        public int TypeID { get; set; }
        [Required(ErrorMessage = "Type is required")]
        public string Type { get; set; }
 public List<BugModel> GetBugHistory { get; set; }    
        [Required(ErrorMessage = "AssignTo is required")]
        public string AssignTo { get; set; }

    }
}

我的控制器是

[AcceptVerbs(HttpVerbs.Post)]    
public ActionResult BugDetails(FormCollection form,string Projects,string Prirority,string CreatedBy,BugModel model)    
{
    var modelList = new List();    
    ViewBag.Projects = new SelectList(GetProjects(), "ProjectId", "ProjectName");    
    ViewBag.Prirority = new SelectList(GetPriority(), "PriorityID", "Prirority");    
    ViewBag.CreatedBy = new SelectList(GetEmployee(), "EmployeeID", "EmployeeName");    
    using (SqlConnection conn = new SqlConnection(@"Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=BugtrackerNew;Data Source=SSDEV5-HP\SQLEXPRESS"))    
    {    
        SqlCommand dCmd = new SqlCommand("Filter", conn);    
        dCmd.CommandType = CommandType.StoredProcedure;    
        conn.Open();    
        dCmd.Parameters.Add(new SqlParameter("@ProjectID", Projects));    
        dCmd.Parameters.Add(new SqlParameter("@PriorityID",Prirority));    
        dCmd.Parameters.Add(new SqlParameter("@CreatedByID",CreatedBy));    
        SqlDataAdapter da = new SqlDataAdapter(dCmd);    
        DataSet ds = new DataSet();    
        da.Fill(ds);
        for (int i = 0; i <= ds.Tables[0].Rows.Count - 1; i++)    
        {
            model.BugID = Convert.ToInt16(ds.Tables[0].Rows[i]["BugID"]);    
            model.Title = ds.Tables[0].Rows[i]["Title"].ToString();    
            model.Description = ds.Tables[0].Rows[i]["Description"].ToString();            
            conn.Close();             
           return View(modelList);
        }
    }    

我的查看页面是

using (Html.BeginForm())    
{ %>   

    <%: Html.DropDownList("Projects", (SelectList)ViewBag.Projects)%>    

    <%: Html.DropDownList("Prirority", (SelectList)ViewBag.Prirority, "Select Project")%>  

    <%: Html.DropDownList("CreatedBy", (SelectList)ViewBag.CreatedBy, "--Select Project--")%>
}

当页面从回发返回时,我希望选择默认值,但是在MVC中没有页面加载方法。 因此,请有人指出正确的方向。

先感谢您。

通过使用DropDownListFor(),可以将所需的项目传递到视图中的模型中。

例:

@{ var projects= (IEnumerable<Projects>)ViewBag.Projects; }


@Html.DropDownListFor(m => m.ProjectId, projects, string.Empty)

简而言之,请使用您的模型确定下拉列表中的选定值,并通过视图包提供可能的值。 如果模型上的属性是属性类型的默认值,则dropdownlistfor将显示列表的第一个值以及可能的值。

暂无
暂无

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

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