Разработка Menu UI компонента. HostBinding, HostListener. Как подписаться на window в Angular?

Поділитися
Вставка
  • Опубліковано 18 січ 2025

КОМЕНТАРІ • 66

  • @grommaks
    @grommaks  3 роки тому +9

    Привет всем :)
    Если вы случайно попали на это видео, то можно начать проходить плейлист с начала
    Со знакомства с Angular ua-cam.com/video/IrelRVjIttA/v-deo.html
    Или с компонентов Angular ua-cam.com/video/U5d_FtO_3NA/v-deo.html
    А если не случайно, то приятного просмотра и спасибо за активность под этим и остальными видео у меня на канале

  • @davidbuloyan1036
    @davidbuloyan1036 3 роки тому +4

    👋👋👋

  • @KvN-UA
    @KvN-UA 2 роки тому +1

    Інформативний урок, дякую!
    Давненько не було нічого нового на каналі, сподіваюсь в тебе все добре.

  • @vovamaestre1136
    @vovamaestre1136 3 роки тому +7

    После просмотра 2-х последних видео, могу с уверенностью утверждать что здесь заявка на лучший контент по ангуляру в СНГ сегменте!
    Спасибо за контент

    • @grommaks
      @grommaks  3 роки тому +1

      Спасибо за такую крутую оценку) скоро больше контента

    • @vovamaestre1136
      @vovamaestre1136 3 роки тому +1

      @@grommaks Пишу это не просто так, поскольку у меня есть опыт продакшин разработки > 1 года, но правда на angularjs, но сейчас перешли на гибрид

  • @alex330k47
    @alex330k47 3 роки тому +1

    О да, Сиси Кеэпвелл. Я не видел его 25 лет но оказалось что до сих пор помню как его зовут. Респект Макс!

    • @grommaks
      @grommaks  3 роки тому

      Ну фамилию его я не знал даже 😺

  • @serdotsenko
    @serdotsenko 3 роки тому +8

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

    • @grommaks
      @grommaks  3 роки тому +5

      Да, по мере роста базы, так и планировал разбавлять примерами которые будут собирать концепции нескольких уроков :)
      Это видео маленький пример того, что я хочу ^_^

    • @nexgenua
      @nexgenua 3 роки тому +3

      По первому вопросу с "несколько асинхронных запросов" то тут ангуляр не при чем, это же rxjs, всякие zip, zipAll, там ничего военного. Обмен данными между компонентами тоже все просто, обычные сервисы с обсерваблами subject или behaviourSubject, в зависимости от задачи, нужно ли текущее значение, ну или ngrx, но там в доке и так все понятно. Вот и весь бестпрактис.

  • @bukanaka
    @bukanaka 3 роки тому +7

    Оооо, взрослый контент)

  • @vitaliybendik6916
    @vitaliybendik6916 2 роки тому +1

    Очень классное решение этой задачи, прям гениально)

  • @njsaab9722
    @njsaab9722 Рік тому +1

    cупер, супер, супер- спасбо большое

  • @awesomeuser789
    @awesomeuser789 2 роки тому

    Как всегда лайк и коммент до начала просмотра) Летим!!!

  • @mykolastrashok9986
    @mykolastrashok9986 3 роки тому +4

    Как всегда полезно и четко! Хотелось бы узнать будут ли видео про тесты в angular? И спасибо за труд!

    • @grommaks
      @grommaks  3 роки тому +3

      Тесты будут, но по плану это через около 4х плейлистов...
      Ориентировочно через пол года может начать появляться контент по тестам

  • @ayub2003
    @ayub2003 11 місяців тому

    Ма шаа Аллах1 брат, хорошие видео

  • @KolkhozDnepr
    @KolkhozDnepr 3 роки тому +1

    Лайк и вечная подписка)))

  • @nexgenua
    @nexgenua 3 роки тому +3

    👍 классные видео! Вдарить еще по ранимой реактовской психике 😊 (не хейчу библиотеку если что) Resolve гвардами, Reuse stratage и сборкой апки для плеймаркета с деплоем, а то народ вроде знает, что угловатый это фреймворк, а вот в чем его фреймворкость и сила до конца не понимают

    • @grommaks
      @grommaks  3 роки тому +1

      Со мной в фирме работают 600 человек на angular и из них деплоями и разбиением занимаются пару человек, я не в их числе))) я больше по ООП и модульной архитектуре…вот когда ковырну описанные практики, то обязательно запишу)

  • @roman_cooper
    @roman_cooper 3 роки тому +1

    спасибо)

  • @diatm1506
    @diatm1506 3 роки тому +3

    Долго ждал. Интересно конечно будет узнать приемущества кастомных деректив. Хочу узнать например в слайдере есть 2 кнопки next и prev в 1 дерективе есть возможность вешать по клику например 2 метода на prev и next handleNext, handlePrev или обработать сразу 2 события? Например клик и если курсор мыши не в поле зрения компонента если не ошибся mouseout то слидер будет листать слайды через 3 секи сам или взависимости от настроек в компаненте. Или нужно много деректив? Например audio player там столько событий... и там в какой-то книге шаблон применялся для плеера

    • @grommaks
      @grommaks  3 роки тому +2

      Нужно делать так, чтобы пользоваться было легко клиентам такого кода, и чтобы когда нужно будет добавить новый функционал в ядро никому ничего не сломать
      Все остальное вкусовщина…и специфика конкретного решения

  • @YuriiD-y1b
    @YuriiD-y1b 3 роки тому +1

    Cool

  • @alexshubin1
    @alexshubin1 Рік тому +1

    Максим, благодарю за конент. Совсем недавно делал меню и остановился на том, как клик снаружи отработать.
    Надо проверить, мне кажется что host-context(.hidden) тоже самое что :host { .hidden { ... }}
    По ссылке на гитхабе кода урока нет, там просто пустой ангуляр проект.

    • @grommaks
      @grommaks  Рік тому

      Странно, проверил ссылку готового урока и код там есть, там две ссылки, первая с кодом и вторая с начальным состоянием для самостоятельной работы

  • @maksmaksim4803
    @maksmaksim4803 3 роки тому +4

    как увидеть 5 недоступных видео которые скрыто?

    • @grommaks
      @grommaks  3 роки тому +4

      Дождаться их публикации, по старому графику, 2 раза в неделю, вт и птн в 10 утра
      А пока они публикуются, я работаю над следующим плейлистом 😃

    • @maksmaksim4803
      @maksmaksim4803 3 роки тому +3

      так так так, с такими уроками, я начинаю понимать что в этот раз мне таки поддастся ангуляр)))) За что тебе огромадное спасибо))

  • @rockyshwilly
    @rockyshwilly 2 роки тому +1

    Очень круто, понятно как все связано, но не понятно почему оно так работает)) Может одна я такая зануда)) Спасибо за видео и объяснения!
    Максим, а есть ли у Вас видео как работать с запросами на backend и как о том, что может быть альтернативой redux в react? А то я пока не понимаю как работать со "стейтом", если его надо передать глубже, чем на одну вложенность, не передавать же дальше через Output - Input?

    • @grommaks
      @grommaks  2 роки тому

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

  • @JlocbBTpaHcE
    @JlocbBTpaHcE 2 роки тому +2

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

    • @grommaks
      @grommaks  2 роки тому +2

      Ваш подход для маленьких проектов самое оно
      Мой подход на больших
      Мой подход сложнее в реализации и понимании но позволяет сильно переиспользовать код, что удешевляет тестирование и поддержку
      Если цель сдать и забыть, то можно не тратить на это время и силы

    • @JlocbBTpaHcE
      @JlocbBTpaHcE 2 роки тому +1

      @@grommaks Да вот именно что приложение просто огромное и включает в себя много маленьких приложений, в понедельник буду готовить 5-6 шаблонов экранов, пока сервисы пишутся. Попробую применить полученные знания на практике, главное что бы начальник не сильно ругался что я от концепции написания компонентов далеко ушел.

    • @grommaks
      @grommaks  2 роки тому

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

    • @JlocbBTpaHcE
      @JlocbBTpaHcE 2 роки тому

      @@grommaks ну да в целом вы правы.

  • @murakami374
    @murakami374 2 роки тому +1

    Привет Максим, досмотрел ролик до момента с тем, где ты в :host положил класс (.menu) , судя по тому, что я нагуглил, вложенность это фишка SCSS , а я делал все на CSS, то есть дальше нет смысла продолжать, мне нужно пересоздать проект?

    • @grommaks
      @grommaks  2 роки тому +1

      Привет, можно просто переименовать файл на Scss и должно работать без доп настроек
      Можно ещё самостоятельно прописывать css код, превращать мои записи в чистый css, я там только вложенностями пользуюсь, это не сложно переписать на обычный css

    • @murakami374
      @murakami374 2 роки тому +1

      @@grommaks если честно, не знаю как это переписать)
      попробую просто поменять расширение на scss

    • @grommaks
      @grommaks  2 роки тому +1

      @@murakami374 желательно почитать что такое scss)
      Все вложенности через пробел пишутся, если есть символ & то без пробела (это склейка с прошлым селектором)

  • @yevhen3934
    @yevhen3934 3 роки тому +1

    Привет, Макс! Хорошее видео :) Спасибо, что быстро и понятно представляешь материалы!
    Мне вот интересный такой вопрос - какое преимущество того, чтобы использовать HostBinding для установки классов нашего хоста, перед самым обычным wrapper'ом/контейнером в темплейте, которому мы будем устанавливать данный класс? Ну, например, используя то же самый [ngClass] или [class] для div'а.
    Также интересно твое мнение о ситуации, когда у нас есть компоненты и часто приходиться добавлять какой-то div в качестве контейнера с какими-то стилями. И я вот видел, что этот контейнер убирают вообще с этими классами, и помещают эти классы в TS-файл, используя HostBinding. С одной стороны это идея, которая может существовать - у нас нету постоянных этих wrapper'ов в компонентах, придерживаясь данного стиля. Но как я думаю об этом - это лишнее. Зачем использовать мощь Ангуляра ради таких вещей (именно лишь для устранения контейнеров в верстке), превращать это в JS-код в bundle'ах, когда можно взять нативщину HTML + class атрибут :) Будет просто и понятно + не надо будет при просмотре темплейтов открывать каждый раз TS-файл, думая "а вдруг там что-то есть". Что скажешь об этом, стоит ли оно того?

    • @grommaks
      @grommaks  3 роки тому +1

      Привет) спасибо за отзыв. В компонентах HostBinding используют редко, чаще обертки делают, тут все верно
      Но hostBinding это способ повлиять на общий между родителем контейнер, и как понимаешь что родитель уже не будет заморачиваться, а логика будет спрятана в ребёнке, не всегда UI либу делает тот же человек что и пользуется ею…
      Почему нужно бороться с лишними дивами? А не нужно, до тех пор пока это не интернет магазин или блог, где Гугл будет срезать поисковые баллы за грязную верстку…если сайт приватный, то тут и заморачиваться не нужно
      HostBinding часто используется в директивах, о чем мы будем говорить, и ещё часто используется в svg компонентах, когда мы не можем раскидываться лишним враппером…
      А так всегда нужно ходить в ts файл и смотреть какие инпуты туда передаются и на что можно подписаться )

    • @yevhen3934
      @yevhen3934 3 роки тому

      @@grommaks , а, вот оно как) Я думал, что это какие-то лишние действия, а оказывается полезная штука в этой ситуации)
      Спасибо за ответ!
      Также есть ситуация, когда у нас есть враппер для какой-то директивы, например scrollToBottom, то здесь HostBinding не поможет, как я понял. Нужно тогда будет или её динамически сетить с ТС кода, ну или же просто на сам хост повесить в родительском компоненте.

    • @grommaks
      @grommaks  3 роки тому

      @@yevhen3934 враппер это компонент?

    • @yevhen3934
      @yevhen3934 3 роки тому

      @@grommaks не, просто div в дочернем компоненте

    • @grommaks
      @grommaks  3 роки тому +1

      @@yevhen3934 если на враппере висит директива то поможет, иначе нужно байндить через привязки компонента

  • @AlexUrsulov
    @AlexUrsulov 2 роки тому +1

    Спасибо за видео, не подскжите как позиционировать host элементы?

    • @grommaks
      @grommaks  2 роки тому

      Есть видео по стилям в angular у меня на канале
      Вроде как в файле scss пишем селектор :host и дальше верстаем

  • @belerafon9288
    @belerafon9288 3 роки тому +1

    А про порталы будет что то? Это же меню через портал было бы интересно посмотреть.

    • @grommaks
      @grommaks  3 роки тому

      Это cdk модуль, пока по нему не будет ничего

    • @belerafon9288
      @belerafon9288 3 роки тому +1

      @@grommaks не именно материаловикий, а вообще такой патерн, для правильного проэцирования выподашек в дереве.

    • @grommaks
      @grommaks  3 роки тому +1

      @@belerafon9288 материал использует angular/cdk, причём по исходникам я смотрел что материал добавляет очень мало в оригинальный cdk, считай ui составляющую.
      Как это сделать без cdk хочу понять, но уже после базовых плейлистов (когда будет понятно о директивах и сервисах)
      P.s. Посмотрел на entry components, они уже deprecated :(

    • @belerafon9288
      @belerafon9288 3 роки тому +1

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

    • @grommaks
      @grommaks  3 роки тому

      @@belerafon9288 спасибо за наводку) попробую ковырнуть

  • @user-san-chous
    @user-san-chous 3 роки тому +1

    в нас на проекте HostBinding и HostListener с самого начала проекта нерекомендованы, насколько помню, так как давно уже о почти забыл об их существовани)) тимлид назвал их тяжелыми (в плане отработки) и устаревшими, если не ошибаюсь. То то скрытие, что в примере, делал бы через ngIf, наверное

    • @grommaks
      @grommaks  3 роки тому

      ngIf убивает DOM елементы и убивает компонент...а при появлении будет все это снова создавать и создавать компонент. Это существенно нагружает чем HostBinding
      А как с директивами работаете тогда?

    • @user-san-chous
      @user-san-chous 3 роки тому +1

      @@grommaks ну вместо ngIf можно и hidden. А вот по поводу HostBinding и HostListener, то нигде не нашел никаких подтверждений их проблемности(( и в группе по Ангуляру админ говорит, что такого не слышал. Возможно наш тимлид говорил только о HostBinding, а HostListener я уже сам приплел. Может ему просто статья какая-то на медиуме попалась субъективная...
      Не, на проекте то есть конечно единичные случаи использования. Например, директива для отлавливания кликов за пределами блока использует только HostListener и еще одна использует вижу HostBinding, хотя сама нигде не применяется) Ну в целом ото и все... А кейсы в видео понравились, то только через пол года от начала проекта задумался, действительно ли то плох HostBinding...

    • @grommaks
      @grommaks  3 роки тому

      @@user-san-chous hidden это visibility hidden который не удаляет елемент из потока html, а лишь его скрывает. Посмотрите разницу между ними)

    • @user-san-chous
      @user-san-chous 3 роки тому +1

      @@grommaks атрибут [hidden]="true" - это не свойство visibility: hiden. Запутали меня) специально ходил проверял. Этот атрибут добавляет display: none, что аналогично примеру в видео будет.
      и надо еще раз будет пересмотреть видео, но если там хостилистенеры в дочерных компонентах, то лучше ngIf применять, имхо.

    • @grommaks
      @grommaks  3 роки тому +1

      @@user-san-chous тогда я пойду ещё почитаю)

  • @user-san-chous
    @user-san-chous 2 роки тому

    Что-то запутался... Не правильнее ли там использовать :host(.hidden) вместо :host-context(:hidden). Клик же в примере вешает класс на хост, а не оборачивает его в этот селектор... host-context вроде же для второго предназначен... Как оно тогда отрабатывает... Ну это надо будет потестить...

    • @grommaks
      @grommaks  2 роки тому +2

      Может я и напутал, хост работает только с хостом, хост контекст добавляет селектор спереди как глобальный, таким образом класс на боди будет влиять на стили

  • @AndrewYurchenko
    @AndrewYurchenko Рік тому

    По существу в Ангуляр использовать display:none конечно можно, но все же.... Предпочтительнее думаю было бы *ngIf. Все же это ангуляр а не просто HTML & CSS в голом виде.
    Также, вот это слово "биндим" ... А русский и английский не ферштейн похоже. Сказать "привязываем" похоже автор не понимает. Все же, если видео заточено на обучение - то и должно нести языковую нагрузку и смыл передавать на том языке, на котором транслируется.
    По поводу "HostBinding" и "HostListener" в общем нормальное объяснение, за исключением вышеописанного.