向视图中添加服务

现在,ASP.NET MVC 6 支持注入类到视图中,和VC类不同的是,对类是公开的、非嵌套或非抽象并没有限制。在这个例子中,我们创建了一个简单的类,用于统计代办事件、已完成事件和平均优先级的服务。

1. 添加命名为Services 的文件夹,在该文件夹下添加名称为 StatisticsService.cs 的类:

StatisticsService 类代码设计如下:

  1. using System.Linq;
  1. using System.Threading.Tasks;
  1. using TodoList.Models;
  1.  
  1. namespace TodoList.Services
  1. {
  1. public class StatisticsService
  1. {
  1. private readonly ApplicationDbContext db;
  1.  
  1. public StatisticsService(ApplicationDbContext context)
  1. {
  1. db = context;
  1. }
  1.  
  1. public async Task<int> GetCount()
  1. {
  1. return await Task.FromResult(db.TodoItems.Count());
  1. }
  1.  
  1. public async Task<int> GetCompletedCount()
  1. {
  1. return await Task.FromResult(
  1. db.TodoItems.Count(x => x.IsDone == true));
  1. }
  1.  
  1. public async Task<double> GetAveragePriority()
  1. {
  1. return await Task.FromResult(
  1. db.TodoItems.Average(x =>
  1. (double?)x.Priority) ?? 0.0);
  1. }
  1. }
  1. }

2. 更新Index 视图注入代办事项数据,在文件顶部添加以下代码声明注入的服务:

@inject TodoList.Services.StatisticsService Statistics

添加标记调用 StatisticsService:

  1. <div>@Html.ActionLink("Create New Todo", "Create", "Todo") </div>
  1. </div>
  1.  
  1. <div class="col-md-4">
  1. @await Component.InvokeAsync("PriorityList", 4, true)
  1.  
  1. <h3>Stats</h3>
  1. <ul>
  1. <li>Items: @await Statistics.GetCount()</li>
  1. <li>Completed:@await Statistics.GetCompletedCount()</li>
  1. <li>Average Priority:@await Statistics.GetAveragePriority()</li>
  1. </ul>
  1. </div>
  1. </div>

以下是该文件的完整代码:

  1. @inject TodoList.Services.StatisticsService Statistics
  1. @{
  1. ViewBag.Title = "Home Page";
  1. }
  1.  
  1. <div class="jumbotron">
  1. <h1>ASP.NET vNext</h1>
  1. </div>
  1.  
  1. <div class="row">
  1. <div class="col-md-4">
  1. @if (Model.Count == 0)
  1. {
  1. <h4>No Todo Items</h4>
  1. }
  1. else
  1. {
  1. <table>
  1. <tr><th>TODO</th><th></th></tr>
  1. @foreach (var todo in Model)
  1. {
  1. <tr>
  1. <td>@todo.Title </td>
  1. <td>
  1. @Html.ActionLink("Details", "Details", "Todo", new { id = todo.Id }) |
  1. @Html.ActionLink("Edit", "Edit", "Todo", new { id = todo.Id }) |
  1. @Html.ActionLink("Delete", "Delete", "Todo", new { id = todo.Id })
  1. </td>
  1. </tr>
  1. }
  1. </table>
  1. }
  1. <div>@Html.ActionLink("Create New Todo", "Create", "Todo") </div>
  1. </div>
  1.  
  1. <div class="col-md-4">
  1. @await Component.InvokeAsync("PriorityList", 4, true)
  1.  
  1. <h3>Stats</h3>
  1. <ul>
  1. <li>Items: @await Statistics.GetCount()</li>
  1. <li>Completed:@await Statistics.GetCompletedCount()</li>
  1. <li>Average Priority:@await Statistics.GetAveragePriority()</li>
  1. </ul>
  1. </div>
  1. </div>

3. 在 Startup.cs 文件中注册StatisticsService 类:

  1. // This method gets called by the runtime.
  1. public void ConfigureServices(IServiceCollection services)
  1. {
  1. // Add EF services to the services container.
  1. services.AddEntityFramework(Configuration)
  1. .AddSqlServer()
  1. .AddDbContext<ApplicationDbContext>();
  1.  
  1. // Add Identity services to the services container.
  1. services.AddDefaultIdentity<ApplicationDbContext, ApplicationUser, IdentityRole>(Configuration);
  1.  
  1. // Add MVC services to the services container.
  1. services.AddMvc();
  1.  
  1. services.AddTransient<TodoList.Services.StatisticsService>();
  1. }

以下是效果图:

发布应用到公有

发布应用到公有云,你需要申请 Microsoft Azure 帐号,如果没有,可以通过以下链接注册:activate your MSDN subscriber benefitssign up for a free trial.

1. 右键点击 TodoList 工程> 发布

2. 在发布对话框中,点击 Microsoft Azure Websites 并登陆公有云帐号。

3. 点击 New。

4. 输入site name 和region。如果你之前没有创建过数据服务器,需要新建,否则可以使用原有的数据库服务器。


数据库服务器是一个宝贵的资源。最好使用现有服务器进行测试和开发。然而由于没有密码校验机制,密码输入错误时不会有错误提示,只有在应用实际访问数据库时才会报错。

5. 在Connection 标签中点击> Next。

6. 在Settings 标签中,选择 KRE 版本。

7. 点击 Publish。

8. 好了,至此你的应用就发布到公有云了,以下是效果图。

以上内容,介绍了如何向视图中添加服务和发布应用到公有云中,大家可以将这些知识运用到实际开发中。开发时还可以借助一些工具。ComponentOne Studio for ASP.NET 是ASP.NET平台上的一整套完备的开发工具包,用于在各种浏览器中创建和设计具有现代风格的Web应用程序。

原文链接:http://www.asp.net/vnext/overview/aspnet-vnext/vc#inj

系列文章目录:

ASP.NET 5系列教程 (四):向视图中添加服务和发布应用到公有云的更多相关文章

  1. ASP.NET 5系列教程 (六): 在 MVC6 中创建 Web API

    ASP.NET 5.0 的主要目标之一是统一MVC 和 Web API 框架应用. 接下来几篇文章中您会了解以下内容: ASP.NET MVC 6 中创建简单的web API. 如何从空的项目模板中启 ...

  2. ASP.NET 5系列教程(七)完结篇-解读代码

    在本文中,我们将一起查看TodoController 类代码. [Route] 属性定义了Controller的URL 模板: [Route("api/[controller]") ...

  3. ASP.NET 5系列教程 (三):view components介绍

    在ASP.NET MVC 6中,view components (VCs) 功能类似于虚拟视图,但是功能更加强大. VCs兼顾了视图和控制器的优点,你可以把VCs 看作一个Mini 控制器.它负责控制 ...

  4. ASP.NET Identity系列教程(目录)

    $(document).ready(function(){ $("#hide").click(function(){ $(".en").hide(); }); ...

  5. C#微信公众号开发系列教程四(接收普通消息)

    微信公众号开发系列教程一(调试环境部署) 微信公众号开发系列教程一(调试环境部署续:vs远程调试) C#微信公众号开发系列教程二(新手接入指南) C#微信公众号开发系列教程三(消息体签名及加解密) C ...

  6. 【ASP.NET Identity系列教程(一)】ASP.NET Identity入门

    注:本文是[ASP.NET Identity系列教程]的第一篇.本系列教程详细.完整.深入地介绍了微软的ASP.NET Identity技术,描述了如何运用ASP.NET Identity实现应用程序 ...

  7. 【ASP.NET Identity系列教程(二)】运用ASP.NET Identity

    注:本文是[ASP.NET Identity系列教程]的第二篇.本系列教程详细.完整.深入地介绍了微软的ASP.NET Identity技术,描述了如何运用ASP.NET Identity实现应用程序 ...

  8. 【ASP.NET Identity系列教程(三)】Identity高级技术

    注:本文是[ASP.NET Identity系列教程]的第三篇.本系列教程详细.完整.深入地介绍了微软的ASP.NET Identity技术,描述了如何运用ASP.NET Identity实现应用程序 ...

  9. Android Studio系列教程四--Gradle基础

    Android Studio系列教程四--Gradle基础 2014 年 12 月 18 日 DevTools 本文为个人原创,欢迎转载,但请务必在明显位置注明出处!http://stormzhang ...

随机推荐

  1. swift 代码添加lable

    let lable1 = UILabel(frame: CGRect(x: CGFloat(self.view.bounds.width/2-20), y: CGFloat(history.frame ...

  2. clone()与clone(true)的区别

    clone()方法用于复制一个元素,但是被复制出来的元素不具备复制的功能,如果希望被复制出来的元素也具备复制的功能,需要给clone()方法加上true这个参数,即clone(true). 例如: & ...

  3. Spring 依赖注入的方式

    Spring 支持3中依赖注入的方式 1.属性注入  通过setter 方法注入Bean的属性或依赖的对象. <bean id = " " class = " &q ...

  4. 运行时报错-Verify the Developer App certificate for youraccount is trusted on your device. Open Settings on Mayoyi_sakura and navigate to General -> Device Management, then select your

    解决方法:打开手机设置->通用->设备管理,找到编辑工程时的ID资料,点击允许即可.

  5. (引用) unittest测试驱动之执行测试(三)

    转载:http://www.wtoutiao.com/p/ydeoyY.html 在unittest的模块中,提供了TestRunner类来进行运行测试用例,在实际的应用中,经常使用的是TextTes ...

  6. knockout.js $index 做列表索引小技巧

    我们都知道,在foreach binding中,使用$index可以得到基于0的索引序号,但在列表显示中,我们更希望这个索引是从1开始的,怎么处理呢? 这里,有个小技巧:使用$index() + 1, ...

  7. php基础-转义字符

    1.php是弱类型语言,定义变量时无需要定义 2.标量类型:整形.浮点型.字符串类型.布尔型 复合类型:数组.对象 其它类型:资源类型(resource如数据库连接,打开文件句柄,资源在不需要时都要释 ...

  8. 云计算和大数据时代网络技术揭秘(十二)自定义网络SDN

    软件定义网络——SDN SDN是网络技术热点,即软件定义网络,OpenFlow是实现SDN思想的一个框架标准, open是指公开.开放,具体为控制平面的规则由各个通信厂家自定义变为公开的技术标准, f ...

  9. 校验两次密码一致的js代码

    function checkpasswd(){ var passwd = document.getElementByIdx_x_x_xx_x('passwd').value; var repasswd ...

  10. Windows 打印控件

    Windows窗体的PrintDocument组件用于设置一些属性,这些属性说明,在基于Windows的应用程序中要打印说明内容以及打印文档的能力,可将它与PrintDialog组件一起使用来控制文档 ...