当前位置:Gxlcms > html代码 > MVC实现简单注册页面_html/css_WEB-ITnose

MVC实现简单注册页面_html/css_WEB-ITnose

时间:2021-07-01 10:21:17 帮助过:26人阅读

刚开始学习MVC,从Webform转过来确实有点费劲好多东东都已经换了一种形式,也在不断的适应这,下面通过讲解一个简单的注册页面来熟悉下MVC中常用的操作。

Model中的User类如下

public class User    {        //用号登录姓名        public string LoginName { get; set; }        //用户密码        public string Password { get; set; }        //用户的电子邮件        public string Email { get; set; }        //用户的手机号码        public string Phone { get; set; }    }


MVC最大的好处就是分离关注点,意思就是我们在开发过程中不用管页面是什么东东,可以先开发业务逻辑,下面是RegisterController中的操作

public class registerController : Controller    {             //注册完的信息显示        public ActionResult Create(FormCollection form)        {            User user = new User()            {                //两种获取方法,一种通过request,一种通过formcollection类                LoginName=form["name"],               // LoginName = Request.Form["loginName"],                Password = Request.Form["password"],                Phone = Request.Form["phone"],                Email = Request.Form["email"]            };            //通过viewdata向界面传递值            ViewData["UserInfo"] = user;            return View();        }        //注册的方法        public ActionResult Reg()        {            //字典类型的键值对            IDictionary star = new Dictionary();            //添加值            star.Add(1, "白羊座");            star.Add(2, "金牛座");            star.Add(3, "双子座");            star.Add(4, "巨蟹座");            star.Add(5, "狮子座");            star.Add(6, "处女座");            star.Add(7, "天秤座");            star.Add(8, "天蝎座");            star.Add(9, "射手座");            star.Add(10, "摩羯座");            star.Add(11, "水瓶座");            star.Add(12, "双鱼座");            //为列表赋值            SelectList starList = new SelectList(star, "key", "value");            //向界面传递值            ViewData["star"] = starList;            return View();        }    }


有了以上的业务逻辑我们就可以实现页面的操作了。

注册页面

<%@ Page Language="C#" Inherits="System.Web.Mvc.ViewPage" %>        Reg  
<% using (Html.BeginForm("Create", "Register", FormMethod.Post)) { %>

用户注册

登录名: <%=Html.TextBox("loginName") %>
密码: <%=Html.Password("password") %>
确认密码: <%=Html.Password("password2") %>
星座: <%=Html.DropDownList("star") %>
性别: <%=Html.RadioButton("sex", true, new { style = "border:0; width:30px;" })%>男 <%=Html.RadioButton("sex", false, new { style = "border:0; width:30px;" })%>女
已婚: <%=Html.CheckBox("married", false, new { style = "border:0; width:30px;" })%>
安全邮箱: <%=Html.TextBox("email") %>输入邮箱
联系电话: <%=Html.TextBox("phone") %>输入联系电话



<%} %>

详细信息页面如下

<%@ Page Language="C#" Inherits="System.Web.Mvc.ViewPage" %>        Create   

用户注册

<% loginMvc.Models.User user = ViewData["UserInfo"] as loginMvc.Models.User; %> 你刚才提交的信息如下:
登 录 名:<%= user.LoginName %>
登录密码:<%= "******" %>
安全邮箱:<%= user.Email %>
联系电话:<%= user.Phone %>

返回重填



案例分析

在上述例子用到了一下几个关键点,下面来分析一下。

1.获取传递值

在上述例子中我们应用两种方法来获取传递的值,分别是FormCollection类和Request对象,这两种用法相同。

2.页面跳转

用到了HtmlHelper类的BeginForm操作,例如Html.BeginForm("Create", "Register", FormMethod.Post),代表以post的方式当页面提交的时候,传递到Register控制器中的Create方法中。该方法参数还有很多,可以自己研究。

3.viewdata向页面返回值,viewdata就好比一个容器,可以装载任何东西,上述实例中就是通过viewdata来传递的。比如在控制器中 ViewData["UserInfo"] = user;把user对象装载到容器中,然后通过页面上的login.models.user user= ViewData["UserInfo"] as loginMvc.Models.User来为页面上的user赋值,需要注意的是,在此需要进行强制转换。

4.viewdata和TempData的区别

ViewData属性是一个ViewDataDictionary类,可用于存储任意对象的数据类型,但存储的键值必须为字符串ViewData有一个特性,就是只会存在于当前的HTTP请求中,而不想session一样,可以将数据带到下一个HTTP请求。与ViewData一样,都属于字典类,不过他中的数据只是一次网页的请求




??

人气教程排行