MVC学习二:Controller和View关系
控制器(Controller)主要是定义方法和加载视图(View)
1.控制器中的Action方法返回值的类型ActionResult,string
2.控制器中Action方法接收浏览器参数方式:
2.1.通过 URL路由中配置的同名参数 --url: "{controller}/{action}/{id}",//Stu/Del/1
public ActionResult Del01(int id)
2.2.通过 Request.Form/Request.QueryString
[HttpPost]
public ActionResult Modify()
{
//model.Id
//model.Name
Request.Form["Name"] return Redirect("/stu/index");
}
[HttpGet]
public ActionResult Modify()
{
//model.Id
//model.Name
Request.QueryString["Name"] return Redirect("/stu/index");
}
2.3.通过 FormCollection
public ActionResult Modify2(FormCollection from)
{
//from["Name"]
return null;
}
2.4.通过 模型绑定 --View中所有空间的名称必须和模型中属性名一致,一般是post过来的才能接收
[HttpPost]
/// <summary>
/// 3.2修改 - 执行修改
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
public ActionResult Modify(Models.Student model)//模型绑定:.NetMVC框架会在调用action方法前,创建 参数model对象,并从请求报文中检查看是否有与该对象属性同名的 数据,如果有,则 设置给 该对象同名的属性
{
DbEntityEntry entry = db.Entry<Models.Student>(model);
entry.State = System.Data.EntityState.Unchanged;
entry.Property("Name").IsModified = true;
entry.Property("CId").IsModified = true;
db.SaveChanges(); return Redirect("/stu/index");
}
视图加载方式:
//--------------------------------------2.0 加载指定视图-----------------------------------
public ViewResult LoadViewBySelf()
{
return View();
//1.0 通过指定 视图名 加载 指定的视图:此视图 必须在 当前控制器同名 的文件夹中
//return View("LoadTarget");
//2.0 通过指定 视图路径 加载指定的视图:基于根目录
return View("~/Views/Home/List.cshtml");
}
控制器向View传递数据
1.控制器类对象创建视图类对象,并把控制器类中的属性ViewBag、ViewData、TempData、Model值赋值给视图类对象的属性ViewBag、ViewData、TempData、Model
1.1.用户访问一个MVC应用程序 例如地址 Home/Index
1.2.服务器通过路由表解析URL,实例化对应的控制器类并调用Action方法(Index),返回ActionResult对象。
1.3.ActionResult对象的ExcuteResult方法就会创建对应的视图类对象(Index_cshtml),通过控制器对象中的ViewBag、ViewData、TempData、Model属性值赋值给View对象中对应的ViewBag、ViewData、TempData、Model。
1.4.调用View对象中Excute方法生成HTML
具体事例:
用户请求 Home/Index 控制器类 home=new 控制器(); ActionResult ar=home.Index(); ar.ExcuteResult();--创建对应的视图对象 Index_cshtml view=new Index_cshtml();
view.ViewBag = home.ViewBag;
view.ViewData = home.ViewData;
.....
view.Excute();
2.ViewBag、ViewData在视图类对象中互相共享的
3.Model是ViewData的Model属性
public ViewResult TransData()
{
////动态数据类型,类似与JS里的对象。
////但是因为 此种对象是在运行时才知道对象的类型,所以编译器和VS都无法推断并产生 智能提示
//dynamic obj = new object();
//dynamic Cla = new ClaController();
//dynamic num = 1;
////动态数据类型 可以动态 添加属性
//obj.AA = 123;
//int a = obj.AA; //3.1 ViewBag
ViewBag.GzItcast = "广州传智播客~~~!";
//3.2 ViewData
ViewData["HnItcast"] = "湖南传智播客~~~!";
//3.3 TempData
TempData["USAItcast"] = "美国传智播客~~~!";
//3.4 Model
Models.Class modelClass = new Models.Class() { CName="德国传智播客~~!" }; ViewData.Model = modelClass;//return View(modelClass)就是把modelClass赋值给控制器对象ViewData属性的Model属性
return View();
}
Views
<html>
<head>
<meta name="viewport" content="width=device-width" />
<title>TransData</title>
</head>
<body>
<div>
@ViewBag.GzItcast <br />
@ViewData["HnItcast"] <br /> @ViewBag.HnItcast <br />
@ViewData["GzItcast"]<br /> @TempData["USAItcast"]<br /> @Model.CName<br /> @ViewData.Model.CName
</div>
</body>
</html>
MVC学习二:Controller和View关系的更多相关文章
- MVC中从Controller像View层传值
MVC中的Controller不能直接的訪问View层中的控件,那么是怎样的将Controller中值传到View中,经常使用的有4种 ViewData: 是获取或设置视图的字典对象,它里面存放的是键 ...
- MVC学习二:基础语法
目录 一:重载方法的调用 二:数据的传递 三:生成控件 四:显示加载视图 五:强类型视图 六:@Response.Write() 和 @Html.Raw()区别 七:视图中字符串的输入 八:模板页 一 ...
- 【转】ASP.NET MVC学习笔记-Controller的ActionResult
1. 返回ViewResult public ActionResult Index() { ViewData["Message"] = "Welcome ...
- MVC 学习系列-Controller
MVC最核心的也就是Controller了,控制器(controller)在功能中起到了核心功能. 1,)在MVC类库中,根据URL,通过MVCHandler进入MVC处理系统中, 2,)解析初始化对 ...
- Thinkphp学习笔记-controller与view绑定
$this->display(); 通过上面的代码则可以输出controller所对应的view
- ASP.NET MVC 四种Controller向View传值方法
控制器: // Get: Data public ActionResult Index() { //ViewData 方式 ViewData["UserName"] = " ...
- angular学习(二):Controller定义总结
上文中总结完了ng-view的应用,将运维后台分开界面到2个,进行到 逻辑Controller处理中,本文将总结一下在项目中Controller都用到了哪些知识: $scope:作用域对象,仅仅是代表 ...
- Spring MVC学习笔记——Controller接口
- spring MVC学习(二)---配置相关的东西
1.在上一节中我们提到过每一个DispatcherServlet都会有一个上下文 (WebApplictionContext),并且继承了这些上下文中的bean,其中以一些"特殊" ...
随机推荐
- mac下安装ionic
我的mac系统是EI Capitan,如下图所示. ionic是一个跨平台的框架,能够提供高效hybrid app的开发,而且性能接近于原生态,具体请参考:http://ionicframework. ...
- BNU29139——PvZ once again——————【矩阵快速幂】
PvZ once again Time Limit: 2000ms Memory Limit: 65536KB 64-bit integer IO format: %lld Java cla ...
- node.js async/await 继发执行与并发执行
async/await 继发执行与并发执行,看如何控制 两个异步函数 foo bar function foo() { return new Promise((resolve, reject) =&g ...
- BindingResult参数验证的跨层次迭代验证
public ResponseWrapper<Object> recordAdd(@RequestBody @Valid ReqAddEnterpriseInfoDTO addEnterp ...
- Machine Learning的定义
---恢复内容开始--- 所下内容都是对吴恩达教授的机器学习所做的笔记 下面是Arthur Samue对机器学习的定义 在没有明确设置的情况下,是计算机具有学习能力的研究领域. 这是一个比较陈旧一点的 ...
- 沙箱模式的chrome浏览器的运行
getUserMedia在chrome 47后已经不可以从非安全源访问(Insecure Origins),但测试搭建apprtc时服务器一般没有添加HTTPS安全验证,chrome就没有权限访问麦克 ...
- URL工具类
UrlUtils = { /** * 判断url是否存在(存在跨域问题) * @param {String} url */ isTrueUrl: function(_url) { result = f ...
- 今日头条极速版邀请码以及其它APP邀请码大全
现在大多手机新闻APP都需要输入码,在网上找了很久,最终找到一个比较全的文章,本人试过,都是可以使用的! 第1个比较好,可边看新闻,边收益!嘻嘻!平时写代码累了,休息刷一下!或者在睡觉前刷新一下,每天 ...
- 使用HTML5 canvas做地图(2)瓦片以及如何计算的
上一篇也说到瓦片,我们为什么使用瓦片?这一篇主要是关于如何拼接地图? 下面的一张图,可以一眼明了,地图是如何切割以及拼接的. 瓦片信息 瓦片信息包括切图原点,瓦片大小,格式,分辨率以及分辨率级别等. ...
- 解决Tensorflow源码安装的之后TensorBoard 无法使用的问题
作者 cnblog 修雨轩陈 我是按照 Tensorflow 下 https://github.com/tensorflow/tensorflow/blob/master/tensorflow/g3 ...