If DOM elements created by Angular, views will be created by default. If we use Jquery or JavaScript to change the DOM structure directly, then no views will be updated. Angular doesn't know that the DOM element is created. So change detection not works for that DOM element.
Directives are markers on the DOM element which tell AngularJS to attach a specified behavior to that DOM element or even transform the DOM element with its children. Simple AngularJS allows extending HTML with new attributes called Directives.
Angular Ivy is a new Angular renderer, which is radically different from anything we have seen in mainstream frameworks, because it uses incremental DOM.
It depends on how your $('site-header') is constructed.
You can try to use $timeout with 0 delay. Something like:
return function(scope, element, attrs) {
    $timeout(function(){
        $('.main').height( $('.site-header').height() -  $('.site-footer').height() );
    });        
}
Explanations how it works: one, two.
Don't forget to inject $timeout in your directive: 
.directive('sticky', function($timeout)
Here is how I do it:
app.directive('example', function() {
    return function(scope, element, attrs) {
        angular.element(document).ready(function() {
                //MANIPULATE THE DOM
        });
    };
});
Probably the author won't need my answer anymore. Still, for sake of completeness i feel other users might find it useful. The best and most simple solution is to use $(window).load() inside the body of the returned function. (alternatively you can use document.ready. It really depends if you need all the images or not).
Using $timeout in my humble opinion is a very weak option and may fail in some cases.
Here is the complete code i'd use:
.directive('directiveExample', function(){
   return {
       restrict: 'A',
       link: function($scope, $elem, attrs){
           $(window).load(function() {
               //...JS here...
           });
       }
   }
});
there is a ngcontentloaded event, I think you can use it
.directive('directiveExample', function(){
   return {
       restrict: 'A',
       link: function(scope, elem, attrs){
                $$window = $ $window
                init = function(){
                    contentHeight = elem.outerHeight()
                    //do the things
                }
                $$window.on('ngcontentloaded',init)
       }
   }
});
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With