在Visual Studio 2017中使用Asp.Net Core构建Angular4应用程(5)

import { BrowserModule } from '@angular/platform-browser';
import { NgModule }
from '@angular/core'; import { FormsModule }from '@angular/forms';
import { HttpModule }
from '@angular/http'; import { AppComponent }from './app.component';

@NgModule({
  declarations: [
    AppComponent
  ],
  imports: [
      BrowserModule,
      FormsModule,
      HttpModule
  ],
  providers: [],
  bootstrap: [AppComponent]
})
export
class AppModule { }

6. 配置.angular-cli.json,tsconfig.json,tsconfig.app.json,tsconfig.spec.json

由于我们使用的是Asp.Net Core集成Angular,所以我们需要告诉Angular将程序输出到wwwroot文件夹。当使用AngularCLI编译Angular时,Angular将会把编译后的文件输出到Asp.Net Core的静态文件目录wwwroot下。

配置如下

image

同样的配置tsconfig.json,tsconfig.app.json,tsconfig.spec.json,tsconfig.json文件是编译TypeScript文件的配置文件。同样需要修改输出位置:

image

image

7. 从Angular中调用Asp.Net Core WebApi

这里我们需要修改app.component.ts文件。

image

image

import { Component, OnInit } from '@angular/core';
import { Http }
from '@angular/http'
@Component({
    selector:
'app-root',
    templateUrl:
'./app.component.html',
    styleUrls: [
'./app.component.css']
})
export
class AppComponent implements OnInit {
    constructor(
private _httpService: Http) { }
    apiValues:
string[] = [];
    ngOnInit() {
       
this._httpService.get('/api/values').subscribe(values => {
           
this.apiValues = values.json() as string[];
        });
    }
}

当Angular在Core上运行之后,他会向ValuesController发出GET请求,并且返回一个字符串数组。

之后我们需要修改ClientApp/app/app.component.html文件,然他来显示WebApi返回的数据:

image

<divstyle="text-align:center">
  <h1>
    这是一个Asp.Net Core 1.1 With Angular4应用程序
 
</h1>
  <h2>下面的信息是由Asp.Net Core WebAPI返回的</h2>
  <ul*ngFor="let value of apiValues">
    <li>{{value}}</li>
  </ul>
  <imgwidth="300" src="">
</div>

其中 *ngFor循环遍历apiValues并一个一个的输出到value中。这是Angular的一种语法。更多语法你需要参阅Angular官方文档。

8. 安装Angular所有依赖项

这一步我们就要用到node了。就是安装AngularCLI一样。使用NPM包管理器。

首先开启Powershell或CMD命令提示行工具,将路径设置到项目根目录。执行如下命令:

npm install

执行该命令后,npm会根据项目中的package.json配置文件安装包括Angular在内的所有依赖包:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/13680.html