Asp.net MVC4之 一个简单的小例子
练习:
新建一个mvc项目
要求:
有3个视图 Login Index Details
目的:
感受一下MVC与传统WebForm的差异性
WebForm的请求模型
MVC请求模型
传统WebForm与MVC区别
WebForm 实际上请求的是一个页面对象
MVC 不仅请求了一个页面对象,还向服务器请求了具体的业务处理方法
程序结构如下
一,项目模板和视图引擎介绍
项目模板
基本: 一般选择这个 它会自动将一些Jquery库导入进来
Internet应用程序:外网使用的
Intranect应用程序:内网使用
Web API:一个轻量级的WebService
知识点:
Web API:使用JSON格式传输数据
WebService:使用XML格式传输数据
视图引擎:
ASPX:在前台用<% %>形式写C#
Razor:在前台用@语法写C#
二,添加一个控制器Controller
控制器模板:
空MVC控制器:只有一个默认的Index方法
包含空的读/写操作的MVC控制器:会将增删改查的Action方法自动添加到当前控制器代码中
三,返回一个String字符串
public string PrintStr()
{
return "hello mvc4";
}
运行后:
四,添加视图Login.cshtml
前台:Login.cshtml
@model MvcApplication1.Models.User
@{
Layout = null;
}
<!DOCTYPE html> <html>
<head>
<meta name="viewport" content="width=device-width" />
<title>Login</title>
</head>
<body>
<div>
<h3>登录</h3>
ViewBag接收后台数据:@ViewBag.tips <br /><br />
Model接收后台数据: @Model.UName <br /><br /> <form action="/User/Login" method="post">
<input type="text" name="UName" /><br /><br />
<input type="password" name="UPwd" /><br /><br />
<input type="submit" value="登入" />
</form> </div>
</body>
</html>
后台:
[HttpGet]
public ViewResult Login()
{
//向前台传值
ViewBag.tips = "hello, welcome to here"; Models.User model = new Models.User();
model.UName = "华子"; return View(model);
}
@{Layout = null;}
表示当前视图不使用默认的母版页
后台向前台传值,有两种方式
ViewBag
Return View(model)
强类型视图
在csdhmtl顶部指定model类型,形式如@model MvcApplication1.Models.User,就叫强类型型视图
好处:在VS中可以智能提示,可以直接写如@Model.UName
五,提交Login.cshtml后重定向
前台:
<form action="/User/Login" method="post">
<input type="submit" value="登入" />
</form>
后台:
[HttpPost]
public ActionResult Login(Models.User model)
{
if (model.UName == "lvhua" && model.UPWD == "")
{
return Redirect("/User/Index");
}
Response.Write("<script>alert('用户名或密码错误');location.href='/User/Login'</script>");
return null; }
重定向
使用Return Redirect (路径) ,相当于Response.Redirect
[HttpPost]和[HttpGet]
如果控制器中有两个同名的Action方法时,应该用.net特性[HttpPost]和[HttpGet]区别
ActionResult和ViewResult
ViewResult 一般用于加载当前视图
ActionResult 一般用于重定向
后台接收前台表单数据
前台表单控件name命名与model属性名相同,后台Action方法参数中就可以用model来接收了,服务器会把表单中的数据加进model里
六,显示Index.cshtml
前台:
@{
Layout = null;
} <!DOCTYPE html> <html>
<head>
<meta name="viewport" content="width=device-width" />
<title>Index</title>
</head>
<body>
<h3>Index</h3>
<div>
@for (int i = 1; i <= 10; i++)
{
<text>@i</text><span>只老虎</span>
<a href="/User/Details/@i">进入</a><br />
} </div>
</body>
</html>
如果只想显示纯文本,可用<text>标签
七,显示Details.cshtml
前台:
@{
Layout = null;
} <!DOCTYPE html> <html>
<head>
<meta name="viewport" content="width=device-width" />
<title>Details</title>
</head>
<body>
<h3>Details</h3>
<div>
<span>第</span>@ViewBag.id<span>只老虎</span>
</div>
</body>
</html>
后台:
public ViewResult Details(int id)
{
ViewBag.id = id;
return View();
}
后台如何获取跳转的id?
前一个页面,遵守RouteConfig的url格式
<a href="/User/Details/@i">进入</a><br />
后台Action方法中参数id即可获取(参数id名称须与RouteConfig配置的id同名)
Asp.net MVC4之 一个简单的小例子的更多相关文章
- 一个简单的小例子让你明白c#中的委托-终于懂了!
模拟主持人发布一个问题,由多个嘉宾来回答这个问题. 分析:从需求中抽出Host (主持人) 类和Guests (嘉宾) 类. 作为问题的发布者,Host不知道问题如何解答.因此它只能发布这个事件,将事 ...
- WebSocket在ASP.NET MVC4中的简单实现
WebSocket在ASP.NET MVC4中的简单实现 2013-12-21 20:48 by 小白哥哥, 810 阅读, 3 评论, 收藏, 编辑 WebSocket 规范的目标是在浏览器中实现和 ...
- 记一次ASP.NET MVC4 升级到MVC5的小问题解决
原文:记一次ASP.NET MVC4 升级到MVC5的小问题解决 .NET 4.0 MVC4版本,升级到.NET 4.6.1 MVC5: 1.使用nuget更新所有 与mvc相关的类库; 2.更改~/ ...
- asp.net mvc4 过滤器的简单应用:登录验证
直接上代码,不要说话. ASP.NET MVC4过滤器的简单应用:验证登录 [AcceptVerbs(HttpVerbs.Post)] public ActionResult login(FormCo ...
- 输出多行字符的一个简单JAVA小程序
public class JAVA { public static void main(String[] args) { System.out.println("-------------- ...
- python -----一个简单的小程序(监控电脑内存,cpu,硬盘)
一个简单的小程序 用函数实现!~~ 实现: cpu 使用率大于百分之50 时 , C 盘容量不足5 G 时, 内存 低于2G 时. 出现以上其中一种情况,发送自动报警邮件! 主要运用 到了两个 模 ...
- 3.2 Lucene实战:一个简单的小程序
在讲解Lucene索引和检索的原理之前,我们先来实战Lucene:一个简单的小程序! 一.索引小程序 首先,new一个java project,名字叫做LuceneIndex. 然后,在project ...
- 给 asp.net core 写一个简单的健康检查
给 asp.net core 写一个简单的健康检查 Intro 健康检查可以帮助我们知道应用的当前状态是不是处于良好状态,现在无论是 docker 还是 k8s 还是现在大多数的服务注册发现大多都提供 ...
- 一个有趣的小例子,带你入门协程模块-asyncio
一个有趣的小例子,带你入门协程模块-asyncio 上篇文章写了关于yield from的用法,简单的了解异步模式,[https://www.cnblogs.com/c-x-a/p/10106031. ...
随机推荐
- IE缓存的BUG 和其他浏览器的缓存问题
原文:IE缓存的BUG 和其他浏览器的缓存问题 1 .IE浏览器在异步请求的时候 为了偷懒 第二次请求的时候不会给后台请求相应,这样我们就无法从后台拿值, 这样的话 ,我们可以画个妆,蒙骗IE我们 ...
- VC6迁移到VS2008几个问题——良好的代码,从我做起,从现在开始。
最近.有一个项目开发,需要使用一次项目的代码.只有当项目VC6下编译通过的,在VS2008下不一定编译通过,能编译通过也不一定能链接成功.以下总结一下我在一个VC6项目移植到VS2008中遇到的一些问 ...
- 呜呼!Node.js是什么?
近期看到非常多站点都使用node.js.開始感到非常好奇.就開始推測这是个什么东西,大概就是个js文件吧,所以開始根本 没有在意,可是越感觉就认为越不正确劲,为什么大家都在用它呢?所以我决定搞个明确. ...
- c++实用技巧
原地址:http://www.cnblogs.com/easymind223/articles/2576904.html 晚上的时间总是习惯性的在cnblogs逛街,今天又看到了好文章,其c++味道浓 ...
- 上mongodb创建一些吸取的经验教训指数
想来接触mongodb它已经快一年了,对于其指数已经积累了很多的经验,知识,以这个夜黑风高的优势,放mongodb总结一番吧. 一,索引介绍 mongodb具有两类索引,分别为单键索引和复合索引. 1 ...
- C语言里为何会有“2+2=5”的结果
写这篇原创文章是由于看到了极客中的一篇文章<有趣各种编程语言实现2+2=5>,当中C语言是这样实现的: int main() { char __func_version__[] = &qu ...
- 利用Gearman实现并发查询(Multi-Query)
这个样例是想从数据库查询出几个结果集,一般的做法是,一个接一个的发送查询,然后汇总结果进行输出. 以下我们利用Gearman的gearman_client_run_tasks实现并发的查询,gearm ...
- POJ-1324-Holedox Moving(BFS)
Description During winter, the most hungry and severe time, Holedox sleeps in its lair. When spring ...
- 单片机实验: 三轴磁场模块 GY-271
最近买了一块三轴磁场模块进行实验 名称:HMC5883L模块(三轴磁场模块) 型号:GY-271 使用芯片:HMC5883L 供电电源:3-5v 通信方式:IIC通信协议 测量范围:±1.3-8 高斯 ...
- 纯CSS实现各类气球泡泡对话框效果
原文 纯CSS实现各类气球泡泡对话框效果 一.关于纯CSS实现气泡对话框 首先,来张大图: 上边这张黄黄的,大大的,圆圆的,有个小尾巴,文字内容有些YY的图片,就是使用纯CSS实现的气泡对话框效果,一 ...