AngularJS - Breeze - EF EntityQuery问题

时间:2015-09-08 17:43:51

标签: angularjs entity-framework-6 breeze

我将在前言中说我是整个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}]

1 个答案:

答案 0 :(得分:0)

我明白了。我的模型类遇到了一些问题,并且从我的datacontext js文件中传回了一些数据命名。