一、简介

通俗的理解,Angular 只是一个前端框架,它只负责前端的事,但一个完整的项目还应该有后端,这其中之一可选的技术就是 asp.net core 。这里简单学习一下两个框架之间的协同开发。

对于现有的轮子,visual studio 已经可以直接创建带有 Angular 模板的 asp.net core 应用。详细教程可以直接翻微软的官方文档,很详细。

创建了带有 angular 模板的 asp.net core 应用之后,前后端的代码都可以在同一个项目下维护,更可以协同调试,以下是创建之后的工程目录。

工程目录

常规上讲,asp.net core 应用遵循 MVC 模式,在创建的模板中,Angular 项目代替了原来 Veiw 部分,也就是说带 angular 应用的 asp.net core 项目仍然还是遵循MVC模式。

根据我阅读文档所得的结论,在这个工程下面我们只需要写 Model 以及 controller 即可,model 好理解,不就是我们从数据库中拿数据之后称放容器的模具嘛。那 controller 是什么?官方文档中说它是处理业务逻辑的东西,那么问题来了,我们要如何调用呢?去哪里调用呢?

二、控制器的调用逻辑

这里需要事先声明,一个请求(Get),即是用户在浏览器输入地址按下回车的时候。

对于一个项目来说,它里面的控制器调用遵循一个路由逻辑。即

/[Controller]/[ActionName]/[Parameters]

举个例子,我这里有个控制器,代码如下

using Microsoft.AspNetCore.Mvc;
using System.Text.Encodings.Web; namespace MvcMovie.Controllers
{
[ApiController]
[Route("[controller]")]
public class HelloWorldController : Controller
{
//
// GET: /HelloWorld/
// 路由走到http://localhost:4200/HelloWorld/ 就会默认调用它,也可能他是第一个缘故
[HttpGet]
public string Index()
{
return "This is my default action...";
} //
// GET: /HelloWorld/Welcome/
[HttpGet]
public string Welcome()
{
return "This is the Welcome action method...";
}
}
}

譬如这里我们的网页运行在 [http://localhost:4200](http://localhost:4200) ,那么如果我这个时候在地址栏输入

http://localhost:4200/HelloWorld/Index
# or
http://localhost:4200/HelloWorld/Welcome

就能够调用这个控制器下的两个方法,这个调用逻辑遵循上面讲述的路由规则,即

/[Controller]/[ActionName]?[Parameters]

所以可以推断出,控制器实际上指的是后端对于页面上所有组件的各种应对逻辑。


三、项目当中的 MVC 结构

对于一个完整的 asp.net core 项目来说,是一个完整的 MVC 结构,项目内的 Angular 工程充当 Veiw ,而微软自带的程序集提供 ControllerModel 支持。当然也可以创建只含有后端的项目,这种项目一般称为 Web API 。其结构也遵循 MVC,只不过缺少了 Veiw

打包之后,Veiw 部分会被编译成静态文件存于生成路径,以供编译生成执行文件调用。

Angular + asp.net core 入门的更多相关文章

  1. CentOS开发ASP.NET Core入门教程

    作者:依乐祝 原文地址:https://www.cnblogs.com/yilezhu/p/9891346.html 因为之前一直没怎么玩过CentOS,大多数时间都是使用Win10进行开发,然后程序 ...

  2. ASP.NET Core 入门教程 10、ASP.NET Core 日志记录(NLog)入门

    一.前言 1.本教程主要内容 ASP.NET Core + 内置日志组件记录控制台日志 ASP.NET Core + NLog 按天记录本地日志 ASP.NET Core + NLog 将日志按自定义 ...

  3. ASP.NET Core入门(一)

    大家好,很荣幸您点了开此篇文章,和我一起来学习ASP.NET Core,此篇文字为<ASP.NET Core入门>系列中的第一篇,本系列将以一个博客系统为例,从第一行代码,到系统发布上线( ...

  4. 【翻译】ASP.NET Core 入门

    ASP.NET Core 入门 原文地址:Introduction to ASP.NET Core         译文地址:asp.net core 简介           翻译:ganqiyin ...

  5. ASP.NET CORE 入门教程(附源码)

    ASP.NET CORE 入门教程 第一课 基本概念 基本概念 Asp.Net Core Mvc是.NET Core平台下的一种Web应用开发框架 符合Web应用特点 .NET Core跨平台解决方案 ...

  6. Angular 5和ASP.NET Core入门

    我希望你们都知道Angular 5已经发布了.在本文中,我们将看到如何使用Angular5TemplateCore开始使用Angular 5和ASP.NET Core. 使用Angular5Templ ...

  7. Asp.net Core 入门实战

    Asp.Net Core 是开源,跨平台,模块化,快速而简单的Web框架. Asp.net Core官网的一个合集,方便一次性Clone 目录 快速入门 安装 一个最小的应用 项目模板 路由 静态文件 ...

  8. 转载: ASP.NET Core入门系列文章

    今天在网上发现了ithome上的asp.net core 系列文章,对于新手入门还不错,这里转载一下,也方便查阅. [Day01] 從頭開始 [Day02] 程式生命週期 (Application L ...

  9. C# & ASP.NET Core 入门官方资料汇总

    借助给公司实习生培训事宜,整理了一些微软官方的适合新同学入门的资料,这里分享一下: 工具: Visual Studio 2017 Community 版本下载地址:https://www.visual ...

随机推荐

  1. Luogu P1314 [NOIP2011 提高组] 聪明的质监员

    P1314 [NOIP2011 提高组] 聪明的质监员 题意 题目描述 给定\(n\)个物品,给定每个物品的 重量 \(w_i\) 和 价值 \(v_i\) 给定一个标准值 \(s\) 以及一个参数 ...

  2. ApacheCN 所有教程/文档集已备份到 Coding

    QuantLearning 数据科学 WIKI 安全 WIKI 团队 WIKI Sklearn 中文文档 PyTorch 中文文档 TutorialsPoint 中文系列教程 Java8 中文官方教程 ...

  3. js源码-自定义数组的pop和shift方法

    本文将自定义_pop和_shift来模拟数组的pop和shift方法 _pop: /* *js中数组的pop方法:删除数组的最后一个元素,把数组的长度减1,并且返回删除的这个元素:如果数组为空,则po ...

  4. AT5760 Manga Market

    首先一个想法就是可以考虑令 \(dp_{i, j}\) 表示当前考虑到了第 \(i\) 个商店,当前到了时刻 \(j\) 能走过最多的商店数量.但是你会发现这个 \(dp\) 转移的顺序并不是简单的从 ...

  5. (4)什么是Ribbon负载均衡

    4.Ribbon负载均衡 上一节中,我们添加了@LoadBalanced注解,即可实现负载均衡功能,这是什么原理呢? 4.1.负载均衡原理 SpringCloud底层其实是利用了一个名为Ribbon的 ...

  6. vi/vim 设置.vimrc(/etc/vim | $HOME)

    转载请注明来源:https://www.cnblogs.com/hookjc/ "====================================================== ...

  7. 今天带大家了解一下ICMP协议及基本使用

    ICMP协议的介绍及基本使用 1.IP数据包头的格式 2.ICMP协议的功能介绍 3.ICMP的基本使用方法 1.在讲解ICMP协议之前,我们先来简单了解一下IP数据包格式如图所示: 2.好现在切入正 ...

  8. shell脚本三剑客之sed

    shell脚本之sed命令 1.概述 2.工作流程 3.命令格式 4.具体操作 1.概述: 1.sed是一种流编辑器,流编辑器会在编辑器处理数据之前基于预先提供的一组规则来编辑数据流 2.sed编辑器 ...

  9. 基于6U VPX TMS320C6678+XC7K325T 的信号处理板

    一.板卡概述 本板卡基于6U VPX结构设计无线电信号处理平台.板卡包含1片C6678芯片,1片 FPGA XC7K325T-2FFG900I:4路AD,4路DA:三个双排插针接口,要求承接前端射频电 ...

  10. 从Spring容器的角度理解Dubbo扩展点的加载时机

    对于Dubbo提供的扩展点,主程序执行的过程中并没有显示调用加载的过程,无论是自激活的Filter还是自适应的ThreadPool.那么这样的扩展点在程序运行的哪个节点调用的呢?跟踪之前性能监控扩展点 ...