**
有人能说出我为什么得到以下信息吗?
**
[shell] Hottowel Angular loaded! nullTypeError:未定义不是Object.fn (/Script/ app /services/directives.js:162:33)在作用域上的函数,在作用域为$文摘(/Script/angular.js:12251:29),$apply(/Script/angular.js:12516:24)在45(/Script/angular.js:8204:45)的XMLHttpRequest.xhr.onreadystatechange (/Script/angular.js:8412:7)的XMLHttpRequest.xhr.onreadystatechange(/Script/angular.js:8351:11)未定义的应用程序上。不是函数对象ReferenceError:在新仪表板(/Script/app/ dashboard /dashboard.js:20:20)的getMessageCount (/Script/app/dashboard/dashboard.js:29:20)、新仪表板(/Script/app/dashboard/dashboard/dashboard.js:20:9)、Object.instantiate (/Script/angular.js:3869:17)、Object.instantiate(/Script/angular.js:3880:23)、Object.instantiate(/Script/angular.js:3880:23)、Object.instantiate(/Script/angular.js:3869:17)上未定义数据文本。地址:6538:34 at forEach (脚本/angular.js:330:20) at nodeLinkFn (脚本/angular.js:6525:11),compositeLinkFn (/Script/angular.js:5986:15)
以下是我的资料
<!-- Vendor Scripts -->
<script src="../Scripts/jquery-2.1.1.js"></script>
<script src="../Scripts/angular.js"></script>
<script src="../Scripts/angular-route.js"></script>
<script src="../Scripts/angular-animate.js"></script>
<script src="../Scripts/angular-sanitize.min.js"></script>
<script src="../Scripts/bootstrap.js"></script>
<script src="../Scripts/toastr.min.js"></script>
<script src="../Scripts/ui-bootstrap-0.6.0.js"></script>
<!-- PouchDB -->
<script src="../Scripts/angular-pouchdb.js"></script>
<!-- Bootstrapping -->
<script src="../Scripts/app/app.js"></script>
<script src="../Scripts/app/config.js"></script>
<script src="../Scripts/app/config.exceptionHandler.js"></script>
<script src="../Scripts/app/config.route.js"></script>
<!--common Modules -->
<script src="../Scripts/app/common/common.js"></script>
<script src="../Scripts/app/common/logger.js"></script>
<script src="../Scripts/app/common/spinner.js"></script>
<!-- common.bootstrap Modules -->
<script src="../Scripts/app/common/bootstrap/bootstrap.dialog.js"></script>
<!-- app -->
<script src="../Scripts/app/dashboard/dashboard.js"></script>
<script src="../Scripts/app/layout/shell.js"></script>
<script src="../Scripts/app/layout/sidebar.js"></script>
<!-- app Services -->
<script src="../Scripts/app/services/datacontext.js"></script>
<script src="../Scripts/app/services/directives.js"></script>我的仪表板在下面
var controllerId = 'dashboard';
angular.module('app').controller(controllerId, ['common', 'datacontext', dashboard]);
function dashboard(common) {
var getLogFn = common.logger.getLogFn;
var log = getLogFn(controllerId);
var vm = this;
vm.news = {
title: 'Hot Towel Angular',
description: 'Hot Towel Angular is a SPA template for Angular developers.'
};
vm.messageCount = 0;
vm.people = [];
vm.title = 'Dashboard';
//Call Active Init
activate();
function activate() {
var promises = [getMessageCount(), getPeople()];
common.activateController(promises, controllerId)
.then(function () { log('Activated Dashboard View'); });
}
function getMessageCount() {
return datacontext.getMessageCount().then(function (data) {
return vm.messageCount = data;
});
}
function getPeople() {
return datacontext.getPeople().then(function (data) {
return vm.people = data;
});
}
}})();
为什么数据文本没有定义?
发布于 2014-05-27 20:34:16
您没有在dashboard定义中加载它。
在这里,您定义了一个控制器,并注入了两个依赖项,common和datacontext,这很好:
angular.module('app').controller(controllerId, ['common', 'datacontext', dashboard]);但是在这里,您将dashboard函数(控制器定义中的最后一个参数)定义为只有一个参数:
function dashboard(common)....so,您正在注入的datacontext实际上被忽略了。您应该将dashboard定义更改为:
function dashboard(common, datacontext) {
...
}https://stackoverflow.com/questions/23898365
复制相似问题