如何在angular指令渲染模板完毕后再执行link方法,render完毕再在link中操作dom节点

解决办法很简单,在link方法中,使用
$timeout(function(){
        ……

});


example

myModule.directive('myTab',['$timeout',function($timeout){
	return {
		restrict:'E',
		repalace:true,
		templateUrl:'19tpl.html',
		scope:{
			myId:'@',
			myData:'='
		},
		controller:['$scope',function($scope){
			$scope.name="ctrl共享的数据";
		}],
		link:function(scope,element,attr,reController){
			//在这里用jq操作dom
			// console.log(scope.name)
			// console.log(element)
			// console.log(attr)
			
			$timeout(function(){
				console.log(element.find('li').length);
				element.find('li').on('click',function(){
					alert(1)
				})
			},0);
		}

	};
}]);

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值