Mel*_*991 5 angularjs angularjs-directive
这是我的指令代码:
// Generated by CoffeeScript 1.6.3
(function() {
var autumnDirectives;
autumnDirectives = angular.module('autumnDirectives', []);
autumnDirectives.directive('timeline', function() {
return {
scope: {
timeline: '='
},
templateUrl: 'partials/timeline/_timeline.html',
controller: function($scope, $element, $attrs) {
return console.log($scope.timeline);
},
link: function(scope, el, attrs) {
console.log(el);
return console.log(el.find(".item"));
}
};
});
}).call(this);
Run Code Online (Sandbox Code Playgroud)
我的模板:
<div class="timeline clearfix">
<div class="item" ng-repeat="item in timeline">
<div class="row">
<div class="content">{{ item.content }}</div>
</div>
<div class="row">
<div class="connect_line"></div><div class="connect_line"></div>
</div>
</div>
</div>
Run Code Online (Sandbox Code Playgroud)
由于某种原因,jqlite find不返回item元素(长度为0) - 或者任何元素.如果我在链接函数中追加一个元素,那么我就能找到它,否则就没有了.
当我记录el时,它会返回正确的元素,如果我冒险进入带有chromes检查工具的孩子,我就能找到.item.
我认为一旦模板准备好就会调用该链接?这里出了什么问题,还是我不明白?
否则一切正常
谢谢
注意:我能够在类中找到层次结构中的第一个div .timeline,但在更深层次上找不到任何内容
你正在生成你的.itemwith ng-repeat. 此时,ng-repeat指令尚未完成渲染。
此时,HTML 看起来像这样:(使用console.log(el[0].outerHTML))
<div timeline="" class="ng-isolate-scope">
<div class="timeline clearfix">
<!-- ngRepeat: item in timeline -->
</div>
</div>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2589 次 |
| 最近记录: |