Angular2官网通过http请求模拟API 来请求hero 数据,感觉有点繁琐,很让人理解不了,我们不采用它的办法,直接展示怎么使用http请求来获取我们的数据 ,直截了当。

第一、准备工作,创建一个WebApi

创建一个webapi(这里我使用MVC4 WebApi ,你可以选择其他途径提供json数据,根据自己需要),返回新闻列表

public class NewsController : ApiController
{
public IEnumerable<News> Get()
{
return AllNews;
}
public News Get(int id)
{
return AllNews.Where(m => m.id == id).First();
}
public List<News> AllNews
{
get
{
return new List<News>()
{
new News(){ id=1,title="title1", click=0, create_date="2017-10-20"},
new News(){ id=2,title="title2", click=0, create_date="2017-10-20"},
new News(){ id=3,title="title3", click=0, create_date="2017-10-20"},
new News(){ id=4,title="title4", click=0, create_date="2017-10-20"},
new News(){ id=5,title="title5", click=0, create_date="2017-10-20"},
new News(){ id=6,title="title6", click=0, create_date="2017-10-20"},
};
}
} }

  由于我们的ajax请求跨域,需要设置允许跨域请求,可以在web.config中增加以下配置

<system.webServer>
<httpProtocol>
<customHeaders>
<add name="Access-Control-Allow-Origin" value="*" />
<add name="Access-Control-Allow-Headers" value="Content-Type" />
<add name="Access-Control-Allow-Methods" value="GET, POST, PUT, DELETE, OPTIONS" />
</customHeaders>
</httpProtocol>
</system.webServer>

  

第二、修改 NewService.ts 的GetNews 方法,数据来自http get请求

1. 在news.service.ts 中 增加 http模块导入

import { Http,Response } from '@angular/http';
import 'rxjs/add/operator/toPromise';

增加构造函数,修改getNews 方法

constructor(private http:Http){}
getNews() {
return this.http.get("http://localhost:63387/api/news/").toPromise()
.then(response=>response.json())
.catch((err)=>{
console.log(err);
});
}

最终代码

import { Injectable } from "@angular/core";
import { News } from './news';
import { NewList } from './mock-news';
import { Http,Response } from '@angular/http';
import 'rxjs/add/operator/toPromise'; @Injectable()
export class NewsService {
constructor(private http:Http){}
getNews() {
return this.http.get("http://localhost:63387/api/news/").toPromise()
.then(response=>response.json())
.catch((err)=>{
console.log(err);
});
}
}

  

2. 修改app.module.ts ,增加HttpModule 支持

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { FormsModule } from '@angular/forms'; import { NewsListComponent } from './news/newslist.component';
import { NewsDetailComponent } from './news/news-detail.component';
import { AppComponent } from './app.component';
import {NewsService} from './news/news.service';
import{ HttpModule} from '@angular/http'; @NgModule({
declarations: [
AppComponent,
NewsListComponent,
NewsDetailComponent
],
imports: [
BrowserModule,
FormsModule,
HttpModule
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }

导入      import{ HttpModule} from '@angular/http';

在         imports 中增加HttpModule

第三、测试运行

npm start 可以看到能正常显示我们的数据了

第四、总结

1. 在需要的Service中,增加导入 Http

import { Http,Response } from '@angular/http';
import 'rxjs/add/operator/toPromise';
 
2.在 app.module.ts 中引入HttpModule,
 
import{ HttpModule} from '@angular/http';
 同时在@NgModule注解中 把HttpModule增加到 imports 中,
 

最新文章

  1. Anliven - To-Do List
  2. mnsday2t1
  3. Windows下给鼠标右键菜单添加获得完全控制权限的菜单项
  4. 5----table类型
  5. Linux配置邮箱发送(MUTT/MSMTPQ)
  6. 12.Warning (15714): Some pins have incomplete I/O assignments. Refer to the I/O Assignment Warnings report for details
  7. java+内存分配及变量存储位置的区别[转]
  8. PHP之implode与explode函数讲解
  9. 纯C++ 连接SQL Server2005 数据库读写操作的小例子
  10. Oracle错误
  11. Html5移动端页面布局通用模板暨移动端问题总结
  12. cron 定时任务
  13. 基于Visual C++2013拆解世界五百强面试题--题9-找出所有的排列方式
  14. Cocos2d-x3.0 文件处理
  15. Tiles布局
  16. css里面position:relative与position:absolute的区别
  17. logistics回归理解
  18. C# IOThread
  19. Link-Cut Tree(LCT)&amp;TopTree讲解
  20. PHP - CentOS下开发运行环境搭建(Apache+PHP+MySQL+FTP)

热门文章

  1. 转-redux-saga
  2. Return type declarations返回类型声明
  3. java入门学习(3)—循环,选择,基础算法,API概念
  4. HDU 1043
  5. runtime 知识点
  6. Android常见问题——Genymotion无法启动问题
  7. Swift UITextField各种属性的设置
  8. 【剑指offer】字符串转换为数字,C++实现
  9. baos bais 意义
  10. 学校项目过程中知识点 Java 2015/9/15 晚