【发布时间】:2016-10-11 19:20:28
【问题描述】:
我使用 JQuery 向 .NET 控制器发出 http 请求(我使用的是 .NET MVC 4.5.2),但现在我开始使用 Angular 2,所以我想用 Angular 2 来处理那些 JQuery AJAX 调用。这是我之前使用的 JQuery,它就像我想要的那样工作:
$.get('/Plan/Variety/ListVarietiesInMenuForSelling')
.done(function(data){
console.log(data)
});
如何设置我的 Angular 2 服务来完成同样的事情?我试过下面的代码:
import { Injectable } from '@angular/core';
import { Http } from '@angular/http';
import 'rxjs/add/operator/toPromise';
@Injectable()
export class SellingMenuVarietiesService {
private url = '/Plan/Variety/ListVarietiesInMenuForSelling'; // URL to web api
constructor(private http: Http) { }
getVarieties() {
return this.http.get(this.url);
}
}
不幸的是,这不起作用。相反,我在控制台中收到此错误:
EXCEPTION: Uncaught (in promise): TypeError: Cannot read property '0' of undefined core.umd.js:3462
我能找到的唯一示例处理 JSON 数据,然后使用 Angular 解析数据并将其格式化为 HTML。我的控制器已经返回了我需要的 HTML,所以我不需要 Angular 来解析 JSON。如何让 http 请求像使用 JQuery 时一样工作?
为了清楚起见,出于测试目的,我将 return this.http.get(this.url); 更改为 return '<h1>test data</h1>'; 并且能够正确显示,所以我知道唯一的问题是 http 请求。
编辑:
这是我调用getVarieties()的代码:
export class SellingMenuVarietiesComponent implements OnInit {
varietyListSelling: any;
constructor(
private router: Router,
private sellingMenuVarietiesService: SellingMenuVarietiesService) { }
ngOnInit(): void {
this.varietyListSelling = this.sellingMenuVarietiesService.getVarieties();
console.log('initializing SellingMenuVarietiesComponent');
}
}
这是我将它绑定到 HTML 的方式:
<div [innerHtml]="varietyListSelling"></div>
我使用它而不是 {{varietyListSelling}},因为我需要将字符串转换为 HTML。
更新
我升级了 TypeScript 并从 app.module.ts 中删除了我的 InMemoryWebApiModule 和 InMemoryDataService 导入,这导致了一个新错误。错误现在显示:EXCEPTION: Unexpected token < in JSON at position 4
这是因为我们将我的 HTML 数据转换为 JSON 吗?我怎样才能像我的 JQuery 一样返回 HTML?
【问题讨论】:
-
能否在调用 getVarieties() 函数的地方添加代码?
-
我编辑了我的帖子以包含该内容
标签: asp.net-mvc angular angular2-services