【发布时间】:2015-05-06 21:36:30
【问题描述】:
我正在尝试让我的第一个 ASP.NET Webforms 和 AngularJS 应用程序启动并运行,但我正在苦苦挣扎......
我创建了一个空白的新 ASP.NET 4.5.1 网络表单应用程序,并将 WebAPI 包含在其中。我为我的客户列表创建了一个示例页面,并使用所有常用的 CRUD 方法创建了一个基于 EF6 的标准 WebAPI CustomerController : ApiController。我使用 Fiddler 测试了那个 WebAPI,结果我发现 - 我从我的数据库中找回了我的 8 个客户。
然而,将它引入 AngularJS 有点不成功,而且非常令人沮丧....
我包含了来自 NuGet 的 AngularJS,这似乎奏效了 - 没有显示任何错误或任何内容,一堆 angular*.js 文件转储到我的 Scripts 文件夹中。
我基于包含<html lang="en" ng-app="TestAngular"> 标签的母版页创建了一个基本的CustomerList.aspx 页面。
为了从 WebAPI 服务获取数据,我创建了我的 Angular 模块,并在 $scope 内创建了一个 model,并创建了一个从 WebAPI 获取数据的服务:
内部app.js:
var testModule = angular.module('TestAngular', [ ]);
testModule.controller('clientController', function ($scope, clientService) {
$scope.model = [];
clientService.getAllClients(function(results) {
$scope.model.clients = results;
});
$scope.model.clientCount = $scope.model.clients.count;
});
testModule.factory('clientService', function ($http) {
var srv = {};
srv._baseUrl = 'http://localhost:56313';
// Public API
return {
getAllClients: function(callback) {
return $http.get(srv._baseUrl + '/api/Customer').success(callback);
}
};
});
根据我对 Javascript 的有限理解,这应该定义一个 clientService(testModule.factory() 调用),它调用我的 WebAPI URL,获取 JSON,然后回调函数将检索到的这些客户填充到 $scope.model.clients属性,$scope.model.clientCount 也应该计算出来。
我的 ASPX 页面如下所示:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="CustomerList.aspx.cs" Inherits="TestAngular.CustomerList" MasterPageFile="~/Site.Master" %>
<asp:Content runat="server" ID="content" ContentPlaceHolderID="MainContent">
<h2>My customers</h2>
<div class="panel panel-default" data-ng-controller="clientController">
We have a total of {{ model.clientCount }} clients in our database table ...
<div class="list-group" data-ng-repeat="client in model.clients">
<div class="list-group-item">
<span>{{ client.Name }}</span><br/>
<span>{{ client.Name2 }}</span><br/>
</div>
</div>
</div>
</asp:Content>
因此,<div> 和 data-ng-controller 应该“连接”该 DIV 与 AngularJS 控制器,应该从 WebAPI 调用加载客户,并将它们包含在模型中,然后使用渲染到 ASPX 页面数据绑定语法({{ client.Name }} 等)
问题是:发生了对 WebAPI 的调用并返回了正确的 8 个客户,但是,当我调试 Javascript 代码时,clientCount 始终为undefined,并且 ASPX 页面仅显示两个空行,这可能将对应于已检索到的客户 - 但为什么只有 2 个,而不是 8 个??
我完全迷失了方向 - 谁能发现我做错了什么,我在这里错过了什么??
【问题讨论】:
标签: angularjs asp.net-web-api webforms