javascript-指令链接功能无权访问整个模板DOM
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript-指令链接功能无权访问整个模板DOM,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1625字,纯文字阅读大概需要3分钟。
内容图文
![javascript-指令链接功能无权访问整个模板DOM](/upload/InfoBanner/zyjiaocheng/680/03162776957e488d9a81c4f7a9e08b93.jpg)
我有一个指令,该指令的模板递归包括一个模板.在我的指令链接功能中,我无法通过选择器获得完整的DOM.
这是我的指令.请注意,我的指令尝试在构造的所有.ui.dropdown div上调用dropdown()函数,因此将激活嵌套的dropdown.
.directive("floatingDropdown", function() {
return {
restrict: 'E',
templateUrl: "scripts/Ui/FloatingDropdown.html",
replace: true,
scope: {
uiClass: '@',
model: '=ngModel',
optionTree: '='
},
link: function(scope, elem, attrs) {
scope.elemClass = scope.uiClass || "ui floating dropdown icon button";
$(elem).dropdown();
$(elem).find(".ui.dropdown").dropdown();
}
}
})
脚本/Ui/FloatingDropdown.html包含嵌套的包含.这会创建多个级别的下拉菜单
<div class="{{elemClass}}">
<script type="text/ng-template" id="node_template.html">
<div class="ui dropdown" ng-if="option.options">
<span ><i class="dropdown icon"></i> {{option.value}}</span>
<div class="menu" ng-if="data.options">
<div class="item" ng-repeat="option in data.options" ng-include="'node_template.html'"></div>
</div>
</div>
<span ng-if="!option.options" ng-click="model=option">{{option}}</span>
</script>
<i class="dropdown icon"></i>
<div class="menu">
<div class="item" ng-repeat="option in optionTree.options" ng-include="'node_template.html'">
</div>
</div>
</div>
我的问题是$(elem).find(“.ui.dropdown”)找不到ng-include递归生成的div
解决方法:
通过在这样的指令的link()方法中尝试执行DOM操作,您正在尝试查询/修改尚未呈现的DOM部分.
您需要将这些jquery调用推迟到以后.您可以使用:
$scope.$evalAsync(function() {
// DOM code
});
要么
$timeout(function() {
// DOM code
}, 0);
使用$evalAsync将在下一个$digest循环中运行该表达式,使您可以在HTML在浏览器中呈现之前对其进行修改.使用$timeout将等待所有$digest循环完成.
内容总结
以上是互联网集市为您收集整理的javascript-指令链接功能无权访问整个模板DOM全部内容,希望文章能够帮你解决javascript-指令链接功能无权访问整个模板DOM所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。