.Net MVC之间的关系以及如何运用
.Net MVC组成部分:视图(views)模型(model)控制器(controller)以及路由(RouteConfig),视图跟模型的数据不进行直接的交互,他们是通过控制器进行视图模型之间的数据交互,现在我们来一步步讲讲视图如何跟模型之间交互。
视图:用来显示客户端界面
模型:用来数据之间的交互
控制器:用来将视图跟模型关联起来
路由:用来配置URL
推荐几篇入门的文章,MVC HtmlHelper用法大全
路由器设置默认加载页面:
路由:
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
routes.MapRoute(
name: "Default",
url: "{controller}/{action}/{id}",
defaults: new { controller = "控制器名称", action = "控制器动作", id = UrlParameter.Optional }
);
}
如何将视图模型控制器关联起来
方法一:
创建视图时,选择对应的模型,去创建。
视图:
@Html.TextBoxFor(model => model.tel, new { @class = "user_input", tabindex = "1" })
在视图中创建,在模型中创建一个字段
模型:
public string tel { get; set; }
在控制器中实例化模型,然后调用模型里面的字段名称,将字段名称赋值,返回字段名,就会产生字段的内容。比如说:
public ActionResult Login(Field field, string textyzm)
{
string tel = field.tel;
return View();
}
方法二:
视图:
@Html.TextBox("texxname", "", new { })
在对应的动作中传递参数,注:参数名要与跟视图创建的名称相同。
控制器:
public ActionResult Index(string textname,)
{
string ss=textname
return Content(ss);
}
提交表单操作
定义一个post请求提交,在控制器里面定义相应的动作,实现表单提交功能。
MVC视图:
<form id="user_form_0" class="user_form" method="post" target="pass_reg_iframe_0" action="#">
<p>
<label id="label_username" for="username">用户名</label>
@Html.TextBoxFor(model => model.name, new { @class = "user_input", tabindex = "1" })
</p>
<p>
<label id="label_password_0" for="password_0">密码</label>
@Html.PasswordFor(model => model.pass, new { @class = "user_input", tabindex = "2" })
</p>
<p>
<label id="label_sex" for="sex">性别</label>
@Html.DropDownListFor(model => model.sex, new SelectList(ViewBag.hard_value, "value", "text"), new { })
</p>
<p>
<label id="label_password_1" for="password_1">确认密码</label>
@Html.PasswordFor(model => model.qrpass, new { @class = "user_input", tabindex = "3" })
</p>
<p>
<label id="label_phone" for="phone">电话</label>
@Html.TextBoxFor(model => model.tel, new { @class = "user_input", tabindex = "4" })
</p>
<p>
<label id="label_mail" for="mail">邮箱</label>
@Html.TextBoxFor(model => model.email, new { @class = "user_input", tabindex = "4" })
</p>
<p class="user_p_verifycode">
<label id="label_verifycode" for="verifycode">验证码</label>
<img id="yzm" name="yzm" onclick="CodeChange()" title="看不清?"
src="/Login/GetValidatorGraphics" tabindex="5" />
</p>
<p class="user_p_img_verifycode">@Html.TextBox("textyzm", "", new
{ @class = "user_verifycode", id = "pass_reg_img_verifycode_0", alt =
"验证码图片", title = "验证码图片" })</p>
<div class="clear"></div>
<p>
<input name="提交" class="user_submit" type="submit" id="user_submit"
style="margin-left:152px;" tabindex="6" value="注册">
</p>
</form>
MVC控制器:
[HttpPost]
public ActionResult Index(Field fiel, string textyzm)
{
//写验证判断验证成功后跳转至index页面
//字段验证
bool tpyz = boolyzmyz(textyzm);
if (tpyz == true)
{
return View("Index");
}
else
{
return View();
}
}
MVC跳转
在视图这种跳转:
<a href="/控制器/控制器动作"></a>
在控制器里面跳转:
return View("控制器动作");
纯手打,转载请标注原文出处。
.Net MVC之间的关系以及如何运用的更多相关文章
- 【整理】JavaEE基本框架(Struts2+Spring+MyBatis三层,Struts MVC)之间的关系
#[整理]JavaEE基本框架(Struts2+Spring+MyBatis三层,Struts MVC)之间的关系 之间的关系
郭晨 软件151 1531610114 [整理]JavaEE基本框架(Struts2+Spring+MyBatis三层,Struts MVC)之间的关系 visio文件下载 概述 一个JavaEE的项 ...
- Surface、SurfaceView、SurfaceHolder及SurfaceHolder.Callback之间的关系
转载请包含网址:http://blog.csdn.net/pathuang68/article/details/7351317 一.Surface Surface就是“表面”的意思.在SDK的文档中, ...
- Android 展示控件之Surface、SurfaceView、SurfaceHolder及SurfaceHolder.Callback之间的关系
一.Surface Surface在SDK的文档中的描述是这样的:Handle onto a raw buffer that is being managed by the screen compos ...
- 转:spring data jpa、 hibernate、 jpa 三者之间的关系
原文链接:spring data jpa. hibernate. jpa 三者之间的关系 spring data jpa hibernate jpa 三者之间的关系 JPA规范与ORM框架之间的关系是 ...
- java设计模式、框架、架构、平台之间的关系
设计模式<框架<架构<平台,从复用角度讲,设计模式是代码级复用.框架是模块级复用.架构是系统级复用.平台是企业应用级复用. 1.设计模式 为什么要先说设计模式?因为设计模式在 ...
- ASP.NET-MVC中Entity和Model之间的关系
Entity 与 Model之间的关系图 ViewModel类是MVC中与浏览器交互的,Entity是后台与数据库交互的,这两者可以在MVC中的model类中转换 MVC基础框架 来自为知笔记(Wiz ...
- .NET Core与.NET Framework、Mono之间的关系
随着微软的.NET开源的推进,现在在.NET的实现上有了三个.NET Framework,Mono和.NET Core.经常被问起Mono的稳定性怎么样,后续Mono的前景如何,要回答这个问题就需要搞 ...
- .NET Core 和 .NET Framework 之间的关系
引用一段描述:Understanding the relationship between .NET Core and the .NET Framework. .NET Core and the .N ...
随机推荐
- IDEA新手下载及和eclipse,myeclipse的区别
一:下载安装包,我们可以去官网下载.下载地址:http://www.jetbrains.com/idea/download/#secation=windows 二:IDEA的安装: 1.下载安装包后双 ...
- console command
routes/console.php copy一个默认的 Artisan::command('hello', function () { $this->comment('hello world' ...
- sum over使用方法,以及与group by的差别
1.sum over使用方法 sum(col1) over(partition by col2 order by col3 ) 以上的函数能够理解为:按col2 进行分组(partition ),每组 ...
- SQL Server游标 C# DataTable.Select() 筛选数据 什么是SQL游标? SQL Server数据类型转换方法 LinQ是什么? SQL Server 分页方法汇总
SQL Server游标 转载自:http://www.cnblogs.com/knowledgesea/p/3699851.html. 什么是游标 结果集,结果集就是select查询之后返回的所 ...
- 仅仅需一步教你解决Win10下Android Studio terminal无法使用的问题
Android Studio集成和加入了一些有用的工具.当中一个便是terminal. 在Windows平台下Android Studio中的terminal在原理上实际使用的是window中的cmd ...
- HTML5开发移动web应用——SAP UI5篇(6)
<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255) ...
- 利用runtime检測这个对象是否存在某属性?
假定有实例对象-instance,我们怎样知道该实例对象是否存在属性-propertyName? 利用runtime,我们能够获取到它的属性列表 1)属性列表 unsigned int outCoun ...
- Android Jni层 创建 linux socket 出错问题解决
问题: 想在Jni层创建 udp socket 与服务端通信,可是没有成功.最后发现居然是创建socket失败(代码例如以下) // create socket g_sd = socket(AF_IN ...
- 使用mpxj读取MSPrjoect
import java.util.ArrayList; import java.util.Calendar; import java.util.Hashtable; import java.util. ...
- [办公应用]如何打印较小边距的PPT讲义(或者每页打印16页)
关键词:打印 PPT 讲义 4张 边距 今天同事问我如何打印PowerPoint的讲义.她自己使用PowerPoint打印讲义,设置每页4张,但是页边距太大:觉得浪费很大. 经过网上查阅后,现将方 ...