©
本文档使用
php.cn手册 发布
ngInit
指令允许你在执行一个当前域中的表达式。
ngInit
只适用于ngRepeat
这种特殊性质的属性,参见下面的示例。除此之外,你应该使用 控制器 而不是 ngInit
来初始化域中的值。ngInit
中同时使用了 $filter
,请确认使用括号来保证正确的优先级:
<div ng-init="test1 = (data | orderBy:'name')"></div>
<ANY
ng-init="">
...
</ANY>
<ANY class="ng-init: ;"> ... </ANY>
参数 | 类型 | 详述 |
---|---|---|
ngInit | expression | 用于计算的表达式。 |
<script>
angular.module('initExample', [])
.controller('ExampleController', ['$scope', Function($scope) {
$scope.list = [['a', 'b'], ['c', 'd']];
}]);
</script>
<div ng-controller="ExampleController">
<div ng-repeat="innerList in list" ng-init="outerIndex = $index">
<div ng-repeat="value in innerList" ng-init="innerIndex = $index">
<span class="example-init">list[ {{outerIndex}} ][ {{innerIndex}} ] = {{value}};</span>
</div>
</div>
</div>
it('should alias index positions', Function() {
var elements = element.all(by.css('.example-init'));
expect(elements.get(0).getText()).toBe('list[ 0 ][ 0 ] = a;');
expect(elements.get(1).getText()).toBe('list[ 0 ][ 1 ] = b;');
expect(elements.get(2).getText()).toBe('list[ 1 ][ 0 ] = c;');
expect(elements.get(3).getText()).toBe('list[ 1 ][ 1 ] = d;');});