4.MVC框架开发(母版页的应用、按钮导致的Action处理、从界面向控制器传数据和HtmlHelper控件的实现(注册的实现))

1.在视图里如何引入母版页

1)在视图里母版页都是放在View目录下面的Shared文件夹下面

2)母版页里的RenderBody()类似于ASP.NET里面的ContentPalceHolder占位符,但是这个RenderBody()只能出现一次

3)@Url.Content是将虚拟路径转换为物理路径的方法

4)在母版页里如果需要别的占位,则就会需要:RenderSection("占位名字",bool值),在子页面就应该这样使用:@section  占位名字{  }

注:如果RenderSection("占位名字",bool值)中的bool值为true,那么在子页面中这个占位在子页面必须用到,false反之

2.在页面里不允许有多个form,只能有一个form,开发的时候建议采用:

@using (Html.BeginForm("Reg", "User",FormMethod.Post, new{ @class="member_form",name="form1"})
{
//里面就是表单的内容Reg为Action,User为控制器,FormMethod.Post为表单提交为post方式,new{ @class="member_form",name="form1"}是表单属性,其中class是关键字,我们采用了@转义的方法,

}

3.如果一个一个页面中有不同的按钮,每个按钮导致不同的Action处理,那么这个时候就需要用JavaScript的方式来改变表单提交时候的Action处理(例如:在表单做一个方法serachFun()),代码如下:

 <script language="javascript" type="text/javascript">
        function serachFun() {
            document.formone.action = "/Book/BookSearch";
            document.formone.submit();
    }
    </script>

4.从界面向控制器传数据

1)通过post表单提交时候的数据传递,是通过表单集合,比如:

 [HttpPost]
        public ActionResult Login(FormCollection fom)
        {
            string userName = fom["username"];
            string userPwd = fom["password"];
            var list = bookshop.Users.Where(p => p.LoginId == userName && p.LoginPwd == userPwd).ToList();
            if (list.Count > 0)
            {
                return RedirectToAction("Index", "Book");
            }
            else
            {
                ViewBag.ErrMessage = "<script>alert('你输入的账户名或者密码错误')</script>";
                return View();
            }
        }

2)在界面中如果要将文本转换成原有的html表示,就用@Html.Raw()方法,比如:

@Html.Raw(ViewBag.ErrMessage)

5.界面中控件的简单说明

对html包装,HtmlHelper这个类,这个类主要就是提供html的一些标签元素的实现,在Razor中应用@Html:

@Html.TextBox("keyword", null, new { @class = "search_key" })
 @*<input type="text" id="keyword" class="search_key" />*@

HtmlHelper控件的实现(注册)

通过模型传递数据的方法

1)将模型的属性映射到表单里的元素名字中,比如映射User这个数据模型,里面有LoginId属性,那么在表单中就有一个name为LoginId的元素

2)当表单向控制器提交数据的时候,方法的参数必须为模型,格式如下:

public ActionResult Reg(MvcBookShop.Models.User UserModel)
        {
            bookshop.Users.Add(UserModel);
            if (bookshop.SaveChanges() > 0)
            {
                ViewBag.MsgRegInfo = "<script>alert('您注册成功')</script>";
            }
            else
            {
                ViewBag.MsgRegInfo = "<script>alert('您注册成功')</script>";
            }
            return View();
        }

有错请留步指导,谢谢啦

你可能感兴趣的:(4.MVC框架开发(母版页的应用、按钮导致的Action处理、从界面向控制器传数据和HtmlHelper控件的实现(注册的实现)))