Хобрук: Ваш путь к мастерству в программировании

Доступ к элементу, к которому привязана директива

Я хочу создать директиву, которая применяется к элементам, чтобы установить их максимальную высоту, равную высоте окна минус расстояние от верхней части элемента до верхней части окна.

я пробовал вот так

.directive('resize', function ($window) {
return function (scope, element) {
    var w = angular.element($window);
    scope.getWindowDimensions = function() {
        return { 'h': w.height() };
    };
    scope.$watch(scope.getWindowDimensions, function(newValue, oldValue) {
        //get header height including margins
        var headerHeight = $('.page-header').outerHeight(true);

        scope.windowHeight = newValue.h;

        scope.style = function() {
            return {
                'height': (scope.windowHeight  - headerHeight) + 'px',
                'max-height': (scope.windowHeight  - headerHeight) + 'px'
            };
        };
    }, true);

    w.bind('resize', function() {
        scope.$apply();
    });
}
})

Но мне пришлось бы добавить var для каждого элемента, который выше элемента, высоту которого я хочу установить. Поэтому я считаю, что с помощью

var scrollTop     = $(window).scrollTop(),
    elementOffset = $('#my-element').offset().top,
    distance      = (elementOffset - scrollTop);

было бы лучше, поскольку он выполняет все измерения относительно элемента, его настройки, но как мне получить доступ к этому элементу из директивы без добавления каких-либо дополнительных классов или идентификаторов?

Также мне нужно создать изолированную область, чтобы я мог использовать ее более одного раза на одной странице?

Моя цель состоит в том, чтобы в основном иметь элемент тела моего веб-приложения, равный высоте окна, и любые содержащие div, которые выше этой высоты, имеют полосы прокрутки.

20.05.2014

Ответы:


1
  • Спасибо, почему вы думаете, что лучше отправить массив элементов в директиву, чем просто измерять сверху элемента? 20.05.2014
  • Я подумал, что если 2 элемента друг за другом используют одну и ту же директиву, то все будет нормально. 21.05.2014
  • Новые материалы

    Основы принципов S.O.L.I.D, Javascript, Git и NoSQL
    каковы принципы S.O.L.I.D? Принципы SOLID призваны помочь разработчикам создавать надежные, удобные в сопровождении приложения. мы видим пять ключевых принципов. Принципы SOLID были разработаны..

    Как настроить Selenium в проекте Angular
    Угловой | Селен Как настроить Selenium в проекте Angular Держите свое приложение Angular и тесты Selenium в одной рабочей области и запускайте их с помощью Mocha. В этой статье мы..

    Аргументы прогрессивного улучшения почти всегда упускают суть
    В наши дни в кругах веб-разработчиков много болтают о Progressive Enhancement — PE, но на самом деле почти все аргументы с обеих сторон упускают самую фундаментальную причину, по которой PE..

    Введение в Джанго Фреймворк
    Схема «работать умно, а не усердно» В этой и последующих статьях я познакомлю вас с тем, что такое фреймворк Django и как создать свое первое приложение с помощью простых и понятных шагов, а..

    Настольный ПК как «одно кольцо, чтобы править всеми» домашних компьютеров
    Вид после 9 месяцев использования С настольных компьютеров все началось, но в какой-то момент они стали «серверами», и мы все перешли на ноутбуки. В прошлом году я столкнулся с идеей настольных..

    Расширенные методы безопасности для VueJS: реализация аутентификации без пароля
    Руководство, которое поможет вам создавать безопасные приложения в долгосрочной перспективе Безопасность приложений часто упускается из виду в процессе разработки, потому что основная..

    стройный-i18следующий
    Представляем стройную оболочку для i18next. Эта библиотека, основанная на i18next, заключает экземпляр i18next в хранилище svelte и отслеживает события i18next, такие как languageChanged,..