• ASP.NET 5简介


    ASP.NET 5简介

    解读ASP.NET 5 & MVC6系列(1):ASP.NET 5简介

    2015-05-13 09:14 by 汤姆大叔, 3379 阅读, 39 评论, 收藏编辑

    ASP.NET 5简介

    ASP.NET 5是一个跨时代的改写,所有的功能和模块都进行了独立拆分,做到了彻底解耦。为了这些改写,微软也是蛮 拼的,几乎把.NET Framwrok全部改写了一遍,形成了一个.NET Core的东西。 在.NET Core里一切都是可配置的,包括Session、MVC等功能,而一切可配置的功能都是可以在Nuget上进行下载。

    目前ASP.NET 5依旧兼容老的.NET Framwrok,但要在进行跨平台的部署,还是只能使用新改版的.NET Core CLR。

    目前的ASP.NET 5包括6个子项目DependencyInjection、EntityFramework、Identity、KRuntime、MVC、SignalR Server,具体每个项目的介绍如下:

    1. DependencyInjection - 基本的依赖注入管理并拥有默认实现
    2. EntityFramework - 数据访问ORM框架
    3. Identity - 用户认证系统
    4. KRuntime - 核心运行时、项目系统,加载器
    5. MVC - MVC框架,整合了MVC、Web API、Web Pages功能
    6. SignalR-Server - 实时交互式服务

    ASP.NET 5所有子项目的开源代码都可以在https://github.com/aspnet/上找到。

    ASP.NET 版本号解释

    5

    新版的ASP.NET称为ASP.NET 5,是一个使用MVC架构开发web应用程序的框架,它还提供了开发RESTful服务的功能。另外,在下个版本里,该框架还可以使用SignalR构建实时应用程序。注意,ASP.NET 5不再包含Web Form开发框架了。

    5也是.NET framework的新版本的版本号,称之为Core50,也叫.NET Core。.NET Core是.NET的重构版本,只保留原有框架中的最小化的功能集,对于其它的特性和功能,可以通过nuget下载以插件的形式运行。这就意味着,我们可以将其用于各种云环境进行独立部署。另外,微软还会提供一个跨平台的.NET Core,以便可以让ASP.NET程序部署到Mac和Unix/Liunx服务器上。另外.NET Core框架还可以和程序一起进行打包部署,从而可以实现在同一台服务器上使用不同版本的.NET Core

    另外,还要注意,.NET Core不包括Web Form、Windows Form、WPF、WCF、Silverlight、System.Drawing、Datatable等功能。也就是说,如果你的程序需要使用System.Drawing进行缩略图制作的话,那就没办法使用了。类似的工具集只能通过Nuget包进行下载了。可以通过工具查找当前程序和.NET Core的兼容性工具集。

    4.5.2

    4.5.2是当前.NET framework全功能版的版本号。你可以使用该版本的.NET来运行ASP.NET 5,甚至是4.5.1版本,使用该版本,可以使用整个.NET体系的所有功能,只不过就不能跨平台了。

    4.6

    4.6是.NET framework全功能版下一版的版本号,也是.NET Core的下一个版本号。你可以将ASP.NET 5应用程序运行在.NET 4.6上,但运行在.NET 4.6上的ASP.NET程序可能不兼容.NET Core。下一个版本的ASP.NET Web Forms也是4.6,其将包括一些增强功能,如异步模型绑定、HTTP2、并开始使用Roselyn编译器。现有的ASP.NET程序(Web Forms、MVC5和之前的版本、Web Pages)不需要任何修改都可以运行在.NET 4.6上。

    6

    ASP.NET 5中的MVC、Web API、Web Pages三个框架会合并成一个框架,统称为MVC6。该合并工作将删除三个框架中重复的功能,比如MVC和Web API中的两种Controller只保留一种。但是传统MVC的功能都会保留,比如模型绑定。不过,据说Web Pages在RTM的时候不会发布,而是会在RTM之后的第一次更新中进行发布。

    MVC6会引入一些新功能,最引人注目的功能就是Tag Helpers和View Components。Tag Helpers是Html Helpers的一种替换,而View Components则引入里类似Web Forms中的WebControl的概念。

    比如,原来的视图模型定义是这样的:

    @using (Html.BeginForm("Register", "Account", FormMethod.Post, new { @class = "form-horizontal", role = "form" }))
    {
        @Html.AntiForgeryToken()
        <h4>Create a new account.</h4>
        <hr />
        @Html.ValidationSummary(true, "", new { @class = "text-danger" })
        <div class="form-group">
            @Html.LabelFor(m => m.UserName, new { @class = "col-md-2 control-label" })
            <div class="col-md-10">
                @Html.TextBoxFor(m => m.UserName, new { @class = "form-control" })
            </div>
        </div>

    在新版MVC6中,我们可以使用Tag Helper进行定义:

    <form asp-controller="Account" asp-action="Register" method="post" class="form-horizontal" role="form">
        <h4>Create a new account.</h4>
        <hr />
        <div asp-validation-summary="ValidationSummary.ModelOnly" class="text-danger"></div>
        <div class="form-group">
            <label asp-for="UserName" class="col-md-2 control-label"></label>
            <div class="col-md-10">
                <input asp-for="UserName" class="form-control" />
                <span asp-validation-for="UserName" class="text-danger"></span>
            </div>
        </div>

    这样的话,就极大地方便了前端开发人员了,因为可以看到正常的HTML结构了。

    View Components则解决了Child Action的问题,比如很多时候,我们都是通过Html.Action来实现菜单、标签功能。如下是一个View Component的示例:

        public class GreetingViewComponent : ViewComponent
        {
            public IViewComponentResult Invoke()
            {
                var greeting = "Good Morning!";
                if (DateTime.Now.Hour > 12)
                {
                    greeting = "Good Afternoon!";
                }
                if (DateTime.Now.Hour > 17)
                {
                    greeting = "Good Evening!";
                }
                return View("Index", greeting);
            }
        }

    该视图组件(view component)也需要响应的视图文件,示例如下:

    @model string
    <h3>@Model</h3>

    调用代码则需要使用权限的Component.Invoke方法,示例如下:

    <div>
        @Component.Invoke("Greeting")
    </div>

    另外还有一个Component.InvokeAsync方法,可以用于异步调用。关于视图组件的详细用法,请参考视图组件一章。

    7

    7是Entity Framework的下一个版本,虽然不属于ASP.NET 5的一部分,但有很大关系。EF7将和ASP.NET 5的RTM版本一起发布,虽然可能延期,但至少在那个时候会有一个可以在.NET Core上运行的基本ORM包,其不包括延迟加载、继承映射、并且只适应于SQL Server。如果不在跨平台上运行MVC6程序的话,你可以在.NET 4.5.2或4.6中继续使用EF6,

    ASP.NET5和MVC6中的10大新变化

    在新版ASP.NET5和MVC6中,有很多变化,有些是彻底的变化,比如在最底层支持依赖注入技术,为了方便了解,我们这里列出了最重要的10大变化,以便进行学习,具体如下:

    1. ASP.NET 5现在已经是跨平台了,可以在Mac和Linux上运行。
    2. 不再有Web Forms框架了。
    3. 只支持C#,不在支持VB.NET了。(貌似最近又听说最终版VB.NET又要支持了)
    4. 新的Tag语法,@Html.LabelFor或Html.TextBoxFor替换成新语法<label asp-for="Name"><input asp-for="Name" />,以便进行模型绑定。
    5. 新增视图组件(View Component),可以将局部内容定义为一个单独的组件进行调用,和Web Forms里的WebControl非常像。
    6. 拥抱前端技术,内置了Nodejs、NPM、Grunt、Bower技术。
    7. 模型整合,将MVC和WebAPI整合成一个框架。
    8. 支持AngularJS,帮内置了AngularJS的module、controller、directive、以及factory模板。
    9. 支持依赖注入技术,拥有原生的DI框架,并且也支持第三方容器。
    10. 支持xUnit.net,并抛弃了Visual Studio Unit Testing框架。

    IDE

    VS2015:VS2015就不用说了,依然高大上,目前不仅支持Nodejs、Python开发,还支持Android和iOS开发。
    Visual Studio Code:为了能够在Mac或Linux操作系统上也能编写C#程序,微软又发布了一个 Visual Studio Code轻量级编辑器可以使用上述操作系统,依然是高大上啊,新功能和特性瞬间秒杀Sublime Text和Brackets,详细地址请访问:https://code.visualstudio.com/ 。

    参考:http://stephenwalther.com/archive/2015/02/24/top-10-changes-in-asp-net-5-and-mvc-6

    同步与推荐

    本文已同步至目录索引:解读ASP.NET 5 & MVC6系列

  • 相关阅读:
    IT民工的时间哪儿来的
    解决Office2007安装时出现错误1706的方法
    情人节特献:有心之函数必然就有分手函数
    mathematica汉化 版本二
    项目经理职责与权利
    什么是产品经理?主要职责是什么?
    调查收藏
    如何在CLI命令行下运行PHP脚本,同时向PHP脚本传递参数?
    PHP的GC垃圾收集机制
    AWStats分析Tomcat\Apache\IIS\nginx 的访问日志
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/4502136.html
Copyright © 2020-2023  润新知