我将在前言中说我是整个Angular / Breeze世界的新手。我看过John Papa关于Pluralsight的视频,所以我对一切都应该如何运作有所了解。我正在使用John Papa的HotTowel Angular Breeze SPA模板。即使在观看了他的视频并做了一些额外的研究之后,我一直在撞墙,试图找出为什么我无法从Breeze / EF获取任何数据回到我的视野。我做了一个现有数据库的“逆向工程师代码”来获取代码第一个文件。我能够获取元数据。我可以在浏览器中提取我试图绑定到我的视图的实体的数据,因此看起来web api部分工作正常。我不习惯调试Angular应用程序,但我在Chrome上的开发人员工具窗口中没有看到任何错误。我确信这很简单,但我没有看到它。任何帮助都是极好的。代码如下。如果我需要发布更多信息请告诉我。
谢谢,
RG
DataContext.js
(function () {
'use strict';
var serviceId = 'datacontext';
angular.module('app').factory(serviceId, ['common', 'entityManagerFactory', 'model', datacontext]);
function datacontext(common, entityManagerFactory, model) {
var $q = common.$q;
var Predicate = breeze.Predicate;
var EntityQuery = breeze.EntityQuery;
var entityNames = model.entityNames;
var getLogFn = common.logger.getLogFn;
var log = getLogFn(serviceId);
var logError = getLogFn(serviceId, 'error');
var logSuccess = getLogFn(serviceId, 'success');
var manager = entityManagerFactory.newManager();
var brand = [];
var service = {
getBrands: getBrands
};
return service;
function getBrands() {
var orderBy = 'BrandID';
return EntityQuery.from(entityNames.brand)
.orderBy(orderBy)
.using(manager).execute()
.then(querySucceeded)
.fail(_queryFailed);
function querySucceeded(data) {
brand = data.results[0];
logSuccess('Retrieved [Brands] from remote data source', brand.length, true);
return brand;
}
}
function _queryFailed(error) {
var msg = config.appErrorPrefix + 'Error retrieving data.' + error.message;
logError(msg, error);
throw error;
}
}})();
控制器
(function () {
'use strict';
var controllerId = 'empLifeCycleHome';
angular.module('app').controller(controllerId, ['common', 'config', 'datacontext', empLifeCycleHome]);
function empLifeCycleHome(common, config, datacontext) {
var getLogFn = common.logger.getLogFn;
var log = getLogFn(controllerId);
var vm = this;
vm.title = 'Employee Life Cycle Home';
vm.brand = [];
activate();
function activate() {
common.activateController(getBrands(), controllerId)
.then(function () { log('Activated Employee Life Cycle Home View'); });
}
function getBrands() {
return datacontext.getBrands().then(function (data) {
return vm.brand = data;
});
}
}})();
查看 - (我使用Controller As语法.Controller是“vm”。)
<section id="empLifeCycleHome" class="mainbar">
<section class="matter">
<div class="container">
<div class="row">
<div class="widget wviolet">
<div data-cc-widget-header title="{{vm.title}}"></div>
<div>
<div data-ng-repeat="b in vm.brand">
<div>
<h5>{{b.brandName}}</h5>
</div>
</div>
</div>
<div class="widget-foot">
<div class="clearfix"></div>
</div>
</div>
</div>
</div>
</section>
导航到品牌操作时在浏览器中返回数据...
[{"$id": "1",
"$type": "EmpSvcsDataModel.Brand, EmpSvcsDataModel",
"BrandID": 1,
"BrandName": "Maintenance USA",
"InsertDate": "2015-09-08T12:58:12.163",
"LastUpdateDate": null}]
答案 0 :(得分:0)
我明白了。我的模型类遇到了一些问题,并且从我的datacontext js文件中传回了一些数据命名。