我无法访问控制器值,一切都未定义。我可以看到日志中的值,但无法访问它们。是否有创建指令和测试其控制器的首选方法。我不想用 .controller('Ctrl') 创建一个控制器,因为它是整个应用程序的全局控制器,它可能被覆盖。
'use strict';
angular.module('Widgets.Module')
.directive('ntGrid', [
'Generator',
function (Generator) {
function postLink(scope, jqElm, attr) { }
function postCompile(tElement, tAttrs) {
return function postLink2(scope, jqElm, attr) {
attr.$observe("ntId", function (id) { // called on on init
scope.ntId = id !== 'generate' ? id : Generator.id;
});
}
}
function CtrlGrid(scope, attrs, Generator) {
var ctrl = scope;
ctrl.dataStatus = 'No Data';
ctrl.isLoading = '';
}
return {
template:
'<div id="{{ ntId }}">' +
'</div>',
controller: [
'$scope', '$attrs', CtrlGrid
],
replace: true,
scope: {
ntId: '@'
},
restrict: 'EA',
link: postLink,
compile: postCompile
};
}
])
;
这是我的测试。
describe('testing ntGrid', function () {
beforeEach(inject(function ($compile, $rootScope) {
$scope = $rootScope.$new();
$scope.data = [
[
{class: 'description', value: 'Header1'},
{class: 'description', value: 'Header2'}
],
[
[
{class: 'value', value: '13'},
{class: 'smallvalue', value: '6,43%'}
],
{class: 'value', value: '12'},
{class: 'smallvalue', value: '4,23%'}
],
[
[
{class: 'negativevalue', value: '-13'},
{class: 'negativevalue smallvalue', value: '-6,43%'}
],
{class: 'negativevalue', value: '12'},
{class: 'negativevalue smallvalue', value: '4,23%'}
]
];
element = angular.element('<div nt-grid nt-table="data"></div>');
$compile(element)($scope);
$scope.$digest();
ctrl = element.data('$scope');
}));
it('test ntGrid html', inject(function () {
console.log(ctrl.ntId)
console.log($scope.ntId)
}));
});