惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Forbes - Security
Forbes - Security
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
F
Fortinet All Blogs
B
Blog
T
The Blog of Author Tim Ferriss
Engineering at Meta
Engineering at Meta
GbyAI
GbyAI
Y
Y Combinator Blog
Microsoft Azure Blog
Microsoft Azure Blog
L
LangChain Blog
Recent Announcements
Recent Announcements
U
Unit 42
Martin Fowler
Martin Fowler
M
MIT News - Artificial intelligence
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
The Register - Security
The Register - Security
Recorded Future
Recorded Future
C
Check Point Blog
V
V2EX
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Hugging Face - Blog
Hugging Face - Blog
WordPress大学
WordPress大学
Google DeepMind News
Google DeepMind News
酷 壳 – CoolShell
酷 壳 – CoolShell
F
Full Disclosure
小众软件
小众软件
A
About on SuperTechFans
云风的 BLOG
云风的 BLOG
宝玉的分享
宝玉的分享
Last Week in AI
Last Week in AI
有赞技术团队
有赞技术团队
MongoDB | Blog
MongoDB | Blog
爱范儿
爱范儿
P
Proofpoint News Feed
罗磊的独立博客
量子位
D
Docker
博客园_首页
D
DataBreaches.Net
Project Zero
Project Zero
博客园 - 司徒正美
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
博客园 - Franky
Security Latest
Security Latest
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
N
Netflix TechBlog - Medium
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
博客园 - 三生石上(FineUI控件)
H
Hackread – Cybersecurity News, Data Breaches, AI and More
大猫的无限游戏
大猫的无限游戏

博客园 - yubinfeng

Git常见问题 [.net 面向对象程序设计深入](9).NET Core 跨平台开发环境搭建 [.net 面向对象程序设计深入](8)认识.NET Core [敏捷开发实践](0) 开始 [敏捷开发实践](2) 用于开发和维持复杂产品的敏捷开发框架Scrum [敏捷开发实践](1) 认识敏捷开发 [.net 面向对象程序设计深入](31)实战设计模式——使用Ioc模式(控制反转或依赖注入)实现松散耦合设计(1) [.net 面向对象程序设计深入](26)实战设计模式——策略模式 Strategy (行为型) [.net 面向对象程序设计深入](18)实战设计模式——设计模式使用场景及原则 [.net 面向对象程序设计深入](36)Redis——基础 《HiWind企业快速开发框架实战》(3)使用HiWind创建和管理菜单 《HiWind企业快速开发框架实战》(2)使用HiWind创建自己的项目 《HiWind企业快速开发框架实战》(1)框架的工作原理 《HiWind企业快速开发框架实战》(0)目录及框架简介 [.net 面向对象程序设计深入](5)MVC 6 —— 构建跨平台.NET开发环境(Windows/Mac OS X/Linux) [.net 面向对象程序设计深入](4)MVC 6 —— 谈谈MVC的版本变迁及新版本6.0发展方向 [.net 面向对象程序设计深入](3)UML——在Visual Studio 2013/2015中设计UML活动图 [.net 面向对象程序设计深入](2)UML——在Visual Studio 2013/2015中设计UML用例图 [.net 面向对象程序设计深入](1)UML——在Visual Studio 2013/2015中设计UML类图
[.net 面向对象程序设计深入](6).NET MVC 6 —— 模型、视图、控制器、路由等的基本操作
yubinfeng · 2016-02-28 · via 博客园 - yubinfeng

[.net 面向对象程序设计深入](6).NET MVC 6 —— 模型、视图、控制器、路由等的基本操作

1. 使用Visual Studio 2015创建Web App

(1)文件>新建>项目,选择Web>ASP.NET Web 应用程序

(2)在新项目MyFirstWebApp对话框中,选择ASP.NET 5模板>Web Application

由于是RC版,这里的”添加单元测试“暂时不能选,上面的WebForms MVC WebAPI将合并,前面一节介绍过了,因此也不需要再选。点确定,完成一个MVC6项目创建。

(3)运行项目

F5在调试模式下运行,或 Ctrl+F5非运行模式下运行

小技巧:启动应用程序 Ctrl+F5(非调试模式)允许您更改代码,文件保存,刷新浏览器,查看代码的变化。很多开发者喜欢使用非调试模式来快速启动应用程序并查看变化。

默认项目是一个响应式的页面,当浏览器窗口缩小或在小屏幕设备上打开时,可以看到导航显示,如下:

2.项目结构

 我们先看一下MVC6和MVC5的项目结构差异:

下面是MVC5项目结构

下面是MVC6项目结构

可以,看到和MVC5相比,项目结构差异比较大

(1)项目文件变成了xproj(MVC5项目文件是csproj)

(2)程序配置文件变为config.json(MVC5则是web.config)

(3)增加了project.json 主要用于项目配置,负责程序集、项目部署设置,部分功能类似于MVC5的package.config.

(4)package.json 这个文件在MVC6中是NPM的配置文件,基于Nodejs的包管理器。

(5)gulpfile.js 是gulp配置文件,gulp是基于Nodejs的Javascript任务管理器,在ASP.NET 5中主要管理NPM和Bower中的内容。

(6)Stratup.cs 程序启动入口,类似于原来的Global.asax

(7)Project_Readme.html 项目说明文件,没什么具体作用。

(8)wwwroot 静太资源文件(如css,images,js等)的存放目录

(9)Dependencies Bower和NPM的依赖管理包。

(10)References 程序集引用,和以前类似,但现在有版本区分(如ASP.NET 5.0 和ASP.NET Core 5.0)

想深入了解MVC6项目结构的朋友,可以参考文章:http://www.cnblogs.com/TomXu/p/4496407.html

3.添加控制器(Controller)

在项目文件夹Controllers右击,选添加>新建项

在打开的对话框中,选择MVC控制器类,取名HelloWorldController.cs

我们打开刚才创建的控制器HelloWorldController.cs更改为如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNet.Mvc;

// For more information on enabling MVC for empty projects, visit http://go.microsoft.com/fwlink/?LinkID=397860

namespace MyFirstWebApp.Controllers
{
    public class HelloWorldController : Controller
    { 

        // GET: /HelloWorld/ 

        public string Index()
        {
            return "这是我的默认动作...";
        }

        // 
        // GET: /HelloWorld/Welcome/ 

        public string Welcome()
        {
            return "我是一个欢迎方法...";
        }
    }
}

View Code

让上面的方法返回一个字符串,F5运行,然在地址后面加上helloworld,刷新一下浏览器,效果如下:

我们打开Startup.cs文件,看一下路由

先找到如下代码:

路由设置的是默认 控制器=Home,方法默认为 Index 参数默认为 id

路由设置格式为 :/[Controller]/[ActionName]/[Parameters]

我们上面指定的控制器,则打开默认的方法Index,如果我们指定方法,运行结果如下:

接着我们看一下参数:

增加如下方法到HelloWorldController.cs

  public string Welcome2(string name, int ID = 1)
  {           
            return HtmlEncoder.Default.HtmlEncode(
                "hello,name:" + name + ",id:" + ID);
 }

注意:上面使用的代码htmlencoder.default.htmlencode保护应用程序免受恶意输入(如JavaScript)。

ID有一个默认值,我们传入参数ID时,默认显示1

传入两个参数:

4.添加视图(View)

(1)先在项目的View目录上创建一个跟控制器同名的文件夹 HelloWorld

比如:视图名为HelloWorld,则对应的控制器名为:HelloWorldController

(2)在视图文件夹HelloWorld中创建视图名为:ViewShow.cshtml,

替换视图文件如下:

@{
    ViewData["Title"] = "Index";
}

<h2>Index</h2>

<p>Hello from our View Template!</p>

并在HelloWorldController,添加同名方法,代码如下:

 public IActionResult ViewShow()
 {
      return View();
 }

然后运行如下图所示地址:

控制器方法View() 为返回视图

5.添加模型(Modle)

模型添加实际是添加一个类文件,这里只是简单创建一个实体,后面会完整介绍

右击项目文件夹Models,添加一个类文件,名为:Movie.cs

内容如下:

public class Movie
{
    public int ID { get; set; }
    public string Title { get; set; }
    public DateTime ReleaseDate { get; set; }
    public string Genre { get; set; }
    public decimal Price { get; set; }
}

到这里一个模型创建完成。

6.总结:

本篇内容非常容易理解,介绍了MVC6基本的控制器、视图、模型的创建及最简单的路由设置,虽然基础,但这些是我们学习MVC的基础,后面有机会继续再介绍MVC的应用。

7.完整源代码下载

Git地址:https://github.com/yubinfeng/BlogExamples

==============================================================================================

返回目录

<如果对你有帮助,记得点一下推荐哦,如有有不明白或错误之处,请多交流>

<对本系列文章阅读有困难的朋友,请先看 《.net 面向对象编程基础》 和 《.net 面向对象程序设计进阶》 >

<转载声明:技术需要共享精神,欢迎转载本博客中的文章,但请注明版权及URL>

.NET 技术交流群:467189533 .NET 程序设计

==============================================================================================