Mvc学习笔记(2)

Razor模板的具体语法使用

因为Razor模板的可以自动识别<>,大大减少了代码量,本节我们一起来探究Razor模板的语法的简单应用:

MVC知识点:

1.ASP.NET Mvc框架 是微软开发的一套新的Web机制

本来的意思是想把以前的前后台紧密联系的WebForm机制改变成灵活的配置方式,但涉及微软觉得每个控制器访问的Model和视图如果都是用配置文件的话,很麻烦。所以微软采取了一中”约定大于配置”的理念。

用户访问某个控制器里的Action方法,就会自动加载同名的视图。

优点:

1.大量的减少了程序员的配置工作

2.本身网站的业务和页面就是配套的,很少有共用或改变的情况

3.可以允许程序员使用不同的视图引擎,从而根据不同的业务和习惯选择不同的视图引擎提高开发效率。

如下图:

public class StudyController : Controller
    {
        //
        // GET: /Study/
       
        public ActionResult Index()
        {
            return View();
        }

    }

假如我们给Study控制器的Action方法添加一个同名的视图,当我们在地址栏里输入 http://localhost:80/study/Index  会访问Views文件夹下的Study文件夹的Index.cshtml。

假如用户访问http://localhost:80/study/Index,我们也可以设置访问 Views文件夹的下的Home文件夹的Test.cshtml

如下图:

public class StudyController : Controller { // // GET: /Study/ public ActionResult Index() { return View("/Views/Home/TT.cshtml"); } }

 

MVC设计模式

是一种用于将具体显示与业务分离,并能通过某种方法灵活改变的代码设计方式。优点在于,用户请求的页面和业务可以灵活配置,降低了页面呈现和后台业务的耦合度。

简而言之:用户请求控制器,控制器【根据配置】决定调用哪个模型来执行业务,并将返回的数据装入哪个视图,最后生成html代码返回用户

下图是视图加载规则,通过mvc找不到视图的错误

技术分享

先去与控制器同名的视图文件夹找

 

Controller获取浏览器的数据

//配置好了的Route规则
public static void RegisterRoutes(RouteCollection routes)
        {
            routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
            routes.MapRoute(
                name: "Default1",
                url: "{controller}/{action}/{id}",
                defaults: new { controller = "Test", action = "TestIndex", id = UrlParameter.Optional }
            );
        }

假如说浏览器请求路径是: /Home/Update/1,MVC框架获取请求后,就会找到匹配的路由映射路径url,得知是请求的控制器类Home里的Update方法,此时就会检查此方法是否包含一个名为id的参数,如果有,按照配置的url获取”参数”{id},并传给此方法。

当一个请求的Url进来以后,会到静态路由表的routes属性的MapRoute方法去匹配路由规则,如果Update有id参数,根据请求的Url将值赋值给方法的id参数

public ActionResult Update(int id)
{
   return View();
}

直接通过请求上下文对象里的 Request获取 url ?后的的参数:

浏览器请求路径为:/User/UserList/1?fun=jp

控制器获取:Request.QueryString["fun"];

可能有人会问为什么这里可以用Request,那是因为Controller类面有Request

技术分享

如上图:我们可以看到Controller类包含了Request、Response、Session、Server、HttpContext属性。这样我们就可以使用Request获取数据

我们还可以通过MVC框架自带的FormCollection 接收数据  如:

public ActionResult Update(FormCollection forms)
{
     string id=forms["id"];
     return View();
}

我们还可以通过实体对象一次性获取表单元素的数据,并设置到实体对象对应的属性中

[HttpPost] public string Update(Student stu) { return stu.Name; }

//下面的是视图的表单 //但是表单的表单元素的属性名必须和实体对象的属性一样 <input type="text" value="333" name="Name" id="Name" />

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。