angularjs – 未调用链接函数

前端之家收集整理的这篇文章主要介绍了angularjs – 未调用链接函数前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我的指令定义如下 –
.directive('codesection',['$compile',function ($compile) {
  return {
      restrict: 'E',scope: { current: '=',parent: '=',index: '=',params: '=' },controller: ['Messages','$scope','Modals','framewidth','$http','$rootScope',function (Messages,$scope,Modals,framewidth,$http,$rootScope) {
          //code
      }],link: function (scope,element,attr) {              
          element.bind('mouSEOver',function (ev) {
              ev.stopPropagation();

              var wrappers = angular.element(document.getElementsByClassName('codesection'));
              angular.forEach(wrappers,function (value,key) {
                  angular.element(value).children('span').removeClass('br');
              });

              element.children('.codesection').children('span').addClass('br');
          });

      },compile: function (tElement,tAttr,transclude) {
          var contents = tElement.contents().remove();
          var compiledContents;
          return function (scope,iElement,iAttr) {
              if (!compiledContents) {
                  compiledContents = $compile(contents,transclude);
              }
              compiledContents(scope,function (clone,scope) {
                  iElement.append(clone);
              });

          };
      },templateUrl: './partials/directives/codesection.html',replace: true
  }
}])

我遇到的问题是永远不会调用链接函数.谢谢!

附:编译逻辑的原因是该指令是递归的.

如果你的意思是链接函数(范围,元素,attr){没有被调用那么它很清楚:编译函数已经返回一个链接函数.什么被定义为链接:不再重要,被忽略.

猜你在找的Angularjs相关文章