在掌握了数据库访问方法之后,我们来看几个mvc的入门程序,借此熟悉mvc的常见工作方式。

一、创建项目,显示一个最简单的页面。

  要点:1、为了突出重点,不使用模版;2、项目类型为mvc,便于获得vs添加的各种引用、文件夹

  如图(vs2017,其他版本大同小异,下同):

  新建项目

  

  选择模版和项目类型

  

  右键控制器文件夹,为项目添加控制器

  

  选择控制器类型(选最新的)

  

  按照惯例,取名为“Home”

  

  完成之后,系统自动创建控制器代码(HomeController.cs),里面默认的方法(操作)是Index。

  对方法里返回的视图的代码点右键,为它添加视图文件

  

  使用默认名称(和控制器里的操作同名),去掉全部选项,使用最干净的视图

  

  在随后生成的文件(可以理解为以前所学的html文件)里,使用网页知识,完成一些简单的内容,如:

  

  上图中,除了汉字,都是自动生成的内容。

  到此为止,最简单的mvc程序完成。右侧资源管理器中可以看到创建的文件

  

  运行之后可以看到效果

  

  注意:地址栏中的“Home”是控制器名称,“Index”是具体操作。它们对应控制器文件中的类和方法。

  以后在调试的时候,如果出现无法在32位环境中运行的内容,可以调整vs的调试器,改为64位环境。具体如下图:

  

  具体位置:

  

二、视图中的语法:Razor

  Razor语法的核心:在一堆html中,随时用“@”符号切换到写C#的模式。

  例1:输出327+254的值

  

  例2:计算1+2+3+...+100的值

  

  c#标记可以和html混写,随时用@切换为C#。

  例3:用无序列表输出1-20

  

  Razor语法的详细介绍,见书上P115。

三、Mvc中的输入和输出:

  1.输出:控制器向视图传值-viewdata,P85

  例:从后台(控制器)向前台(视图)传递内容  

public ActionResult Index()
{
ViewData["d1"] = "我是来自后台的ViewData数据";
TempData["d1"] = "我是来自后台的TempData数据";
return View();
}

  运行效果:

  

  2.输入:视图向控制器传值-表单知识,P102

  例:输入一个数字,翻倍把它输出。

  控制器代码:  

public class HomeController : Controller
{
// GET: Home
public ActionResult Index(int a=)//此处的a=0表示默认值
{
ViewData["d1"] = a;
return View();
}
}

前台代码:  

@{
Layout = null;
} <!DOCTYPE html> <html>
<head>
<meta name="viewport" content="width=device-width" />
<title>Index</title>
</head>
<body>
<div>
@{int x = int.Parse(ViewData["d1"].ToString());
if (x == )
{
<div> 还没输入值 </div>
}
else
{
<div>已输入值@(x)</div>
<div>它的2倍是@(x * )</div>
}
}
</div>
<div>
<form action="/home/index">
<input type="text" name="a" /><input type="submit" />
</form>
</div>
</body>
</html>

  以上例子是把运算放在了视图中,我们还可以把它放在控制器中运行,大家尝试一下。

  对于标准的mvc结构来说,这种运算应该算是“业务逻辑”,应该放在业务层处理。这里只是为了演示视图和控制器的工作方式。

  Request作为内置对象可以获取跟请求用户相关的内容。在获取表单内容方面,无论用户是用get还是post方式提交,都可以通过Request[key]的方式获取内容。

  例,控制器代码:  

public ActionResult Index()
{
if (Request["a"] == null)
{
ViewData["a"] = "空";
}
else if (Request["a"] == "")
{
ViewData["a"] = "无";
}
else
{
ViewData["a"] = Request["a"];
}
return View();
}

  视图代码:  

@{
Layout = null;
} <!DOCTYPE html> <html>
<head>
<meta name="viewport" content="width=device-width" />
<title>Index</title>
</head>
<body>
<div>
@ViewData["a"]
<form id="form1" name="form1" method="put" action="/Home/Index">
<label for="a"></label>
<input type="text" name="a" id="a" />
<input type="submit" />
</form>
</div>
</body>
</html>

  大家可以自行熟悉使用

四、综合实例

  1、输入数字n,在屏幕上输出n层的杨辉三角形。

  控制器代码:  

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc; namespace WebApplication1.Controllers
{
public class HomeController : Controller
{
// GET: Home
public ActionResult Index(int n=)//此处的a=0表示默认值
{
if (n == )
{
ViewData["d1"] = null;
}
else
{
int[,] a;
a = new int[n,n];
for (int i = ; i < n; i++)
{
a[i, ] = ;
}
for (int i = ; i < n; i++)
{
for (int j = ; j <= i; j++)
{
a[i, j] = a[i - , j - ] + a[i - , j];
}
}
ViewData["d1"] = a;
}
return View();
}
}
}

  视图代码:  

@{
Layout = null;
} <!DOCTYPE html> <html>
<head>
<meta name="viewport" content="width=device-width" />
<title>Index</title>
</head>
<body>
<div>
@if (ViewData["d1"] != null)
{
<table style="width: 100%; border-color:black; padding:0px; border-collapse:collapse;" border=''>
@{
int[,] a = (int[,])ViewData["d1"];
for (int i = ; i < a.GetLength(); i++)
{
<tr>
@for (int j = ; j <= i; j++)
{
<td>@(a[i, j])</td>
}
</tr>
}
}
</table>
}
</div>
<div>
<form action="/home/index">
<input type="text" name="n" /><input type="submit" />
</form>
</div>
</body>
</html>

  2、结合数据库知识,完成一个能对数据库实现简单“增删改查”的项目。

最新文章

  1. OpenCV2:特征匹配及其优化
  2. nodejs学习笔记四——express-session
  3. oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务。
  4. java中日历代码的实现
  5. Xshell中文乱码问题
  6. exe4j中&quot;this executable was created with an evaluation错误解决方法
  7. How to Move Magento to a New Server or Domain
  8. 9.6. MySQL中保留字的处理
  9. 使用ajaxfileupload插件提示Uncaught TypeError:has no method &#39;handleError&#39;
  10. C#主要支持 5 种动态创建对象的方式
  11. Discuz X3.2 SEO设置 title 不支持空格的解决方法
  12. 二、UITableView和它的亲戚们
  13. Android ART运行时无缝替换Dalvik虚拟机的过程分析
  14. 在Cyclone IVE中使用进位链的几个规则
  15. Python字符串和列表的内置方法
  16. SQL Server进阶(十一)存储过程
  17. 读取配置文件的URL,使用httpClient发送Post和Get请求,实现查询快递物流和智能机器人对话
  18. profile bashrc bash_profile 之间的区别和联系
  19. pyDay4
  20. 如何把he_llo wo_rld 变成 HeLlo WoRld

热门文章

  1. Linux的DNS实现负载均衡及泛域名部署
  2. Eric6安装问题解决
  3. wordpress迁移后登陆时出现Forbidden You don’t have permission to access /wp-login.php on this server
  4. HTTP协议的异步通信
  5. discuz开发实现自动获取后台入口代码
  6. Ubuntu18.04安装redis-server启动出错
  7. python接口自动化框架
  8. 动态规划大合集II
  9. docker 部署 jenkins
  10. C语言-malloc