Angular unsubscribe, Angular async pipe, RxJS subscribe - Avoid Memory Leaks

Поделиться
HTML-код
  • Опубликовано: 25 янв 2025

Комментарии • 92

  • @MonsterlessonsAcademy
    @MonsterlessonsAcademy  4 месяца назад

    WATCH NEXT: Angular Interview Questions and Answers - Dominate Your Next Interview - ruclips.net/video/5A_YKlVWMPo/видео.htmlsi=2DCn7yspEAAJ2H6l

  • @luczztem
    @luczztem Год назад +6

    broo the extended class approach is genius

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  Год назад

      Thank you!

    • @programmistka_v_amerike
      @programmistka_v_amerike 6 месяцев назад

      Until for some reason we need to extend another class and TS doesn't support multiple inheritance.
      All the other solutions are indeed most used to avoid memory leakage. Also, multiple subscriptions can be also pushed to an array and looped through to unsubscribe from in the ngOnDestoy hook.

  • @riketscience
    @riketscience Год назад +2

    The last part at 09:12 is very nice indeed. I really like this kind of work. A great solution for many applications. Once again, great content my friend. 👍

  • @chinmayapandya8990
    @chinmayapandya8990 2 года назад +2

    superb explanation of all possible ways of avoiding memory leaks for RxJS subscriptions. Thank you so much ! 🙂

  • @izacaqsha3480
    @izacaqsha3480 Год назад +1

    You are awesome sir,
    keep making videos like this !!!
    You are teaching a lot of newbies and experienced programmers!!

  • @bizmarinainfo1808
    @bizmarinainfo1808 Год назад +1

    Excellent short and consolidated walkthrough. Thanks for posting.

  • @rizaanjappie
    @rizaanjappie 2 года назад +1

    This channel is underrated.

  • @hamza201183
    @hamza201183 2 года назад +2

    High quality information as always. Many thanks Oleksandr!

  • @austinZen8800
    @austinZen8800 2 года назад

    Thanks!

  • @lianayukhymchak5328
    @lianayukhymchak5328 Год назад

    Дякую! Дуже круте відео, все чітко і зрозуміло!) Thanks a lot!)

  • @kirole7381
    @kirole7381 Год назад

    Best and straightforward...but i just see in my navbar one of your videos..
    that async pipe is broken in Angular

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  Год назад

      Yes, you are right
      ruclips.net/video/Z9U9-VRN_XU/видео.htmlsi=WUum9t-zTDwQ078W

  • @valikonen
    @valikonen 2 года назад +3

    Amazing post. Maybe you'll make more with RxJS and also with complex Directives. Thank you!

  • @mirodz21
    @mirodz21 Год назад

    amazing explanation. super helpful!

  • @krzaqabc
    @krzaqabc 2 года назад +4

    You provide very valuable content, thank you Olexander
    PS Olexander, consider creating new angular course but even more advanced than medium one - by saying more advanced i mean using bigger spectrum of RxJs operators, change detection strategy, NG rx, using facade pattern, and such tricks like this one with extending abstract class, strict mode, use of firebase? This is just my idea, but knowing your skills as a teacher and experienced developer it would be Very valuable and helpful for developers on any 'level', best regards and stay healthy!

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  2 года назад +2

      Thank you for the idea. I will add it to the list of future courses!

  • @transforgoku
    @transforgoku Год назад

    Excellent video, I think I'm gonna stick to async pipe and avoid suscriptions, Oninit and Ondestroy altogether in my code...

  • @its_vincesanity
    @its_vincesanity 2 года назад

    This is pretty awesome! Love that's it's so easy to implement but so valuable. Thanks!

  • @BennyS6502
    @BennyS6502 11 месяцев назад

    Nice video 👍
    I would just like to mention that since version 16, Angular has introduced the "takeUntilDestroyed()" operator, which solves this problem.
    One question, why did you decorate the parent class "Unsub" with "@Injectable()"? In your example, it is not used as a service provided via dependency injection.
    Thanks!

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  11 месяцев назад +1

      I covered takeUntilDestroyed in a separate video
      ruclips.net/video/ddyxKtfOMqU/видео.htmlsi=i1RHZVQud8YKES4A
      Yes Unsub doesn't need injectable. It's just a habbit.

  • @tarasshevchuk8477
    @tarasshevchuk8477 Год назад

    Thank you ! Very useful information !

  • @fuji91
    @fuji91 Год назад

    Sorry for the dumb question, but what if I have:
    data$ = interval(1000);
    const x$ = this.data$.pipe(take(1));
    x$.subscribe((data) => console.log('data', data));
    Which of the observables does the take(1) operator specifically complete?

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  Год назад

      It's not dumb. x$ is a new observable based on data$. As you subscribe to x$ it has a take function

  • @mrlindaring
    @mrlindaring 7 месяцев назад

    Brilliant! Thank you.

  • @PackAndGoFamily
    @PackAndGoFamily Год назад

    Hi, i find this approach very interesting also. DO you might wanna do a short video about that option too.
    takeUntilDestroyed with destroyRef which close "Automatically" the sub.

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  Год назад

      Hi, I already did that
      ruclips.net/video/ddyxKtfOMqU/видео.htmlsi=iAcYmh8rOUI-w6ZX

  • @msiyam
    @msiyam Год назад

    Many Many Thanks to you sir, You make my day

  • @dhmilmile1
    @dhmilmile1 6 месяцев назад

    What should we do if we need ngOnDestory in the child component or how we can override it?

  • @ndthinh91
    @ndthinh91 Год назад

    Thank for your awesome content

  • @ugochukwuumerie6378
    @ugochukwuumerie6378 2 года назад

    Legend! Thanks for the awesome content especially the custom takeUntil(), pretty useful

  • @chagamajaykumarreddy1897
    @chagamajaykumarreddy1897 2 года назад

    amazing stuff, we need to call super right if we use this class as a common for all components ?

  • @danilo_teixeira
    @danilo_teixeira Год назад

    Very nice video man, congrats! Could you make a video talking about the new operator released in Angular 16, the "takeUntilDestroyed()"

  • @VasyaFF
    @VasyaFF Год назад

    Is it correct that we should use ReplaySubject, NOT Subject for unsubscription?
    After component destroyed it is possible that Subject is destroyed too, but subscription NOT. And subscription survive after destroy. But ReplaySubject can "shot" one more time after component destroy and subscription will be completed.

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  Год назад

      You can but there is no memory leak is subscribes if you use takeUntil or unsubscribe. Doesn't matter if it is subject, behaivourSubject or replaySubject.

  • @imriharlev5151
    @imriharlev5151 2 года назад

    Thank you for the good content 🤩

  • @sergiocebrian85
    @sergiocebrian85 2 года назад

    I still remember several projects where the people forgot to close subscriptions...

  • @serhiitachuk
    @serhiitachuk 2 года назад

    Hello! I love your video so much. Where is the best place to support you? On your platform or udemy (as far as I know udemy takes some commission)?

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  2 года назад +1

      Comission is everywhere -_-. Buying my courses or subscription on the website has the smallest comission and gives you knowledge in return.
      monsterlessons-academy.com/courses
      If you don't need a course but just want to support me there is a membership on youtube channel.

  • @rohit36910
    @rohit36910 11 месяцев назад

    Should i unsubscribe route change as well

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  11 месяцев назад

      Angular does it for us but I prefer to just unsub for every subscribe I see

  • @ArthunMorgan747
    @ArthunMorgan747 Год назад

    Hi, can you tell us which IDE you are using? :)

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  Год назад

      It's Vim

    • @ArthunMorgan747
      @ArthunMorgan747 Год назад

      @@MonsterlessonsAcademy Okie I am little confused as I am learning angular,should I use vscode or vim? I know it is just IDE but still which has better support?

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  Год назад

      @@ArthunMorgan747 You should use vscode and focus on learning programming and not configuring the editor which with vim will take a lot of time.

    • @ArthunMorgan747
      @ArthunMorgan747 Год назад

      @@MonsterlessonsAcademy thank you 😁

  • @LailahaillallahTv
    @LailahaillallahTv 2 года назад

    how would you call abstract unsub class while your component already extends other class? in typescript you cant extend two class. do you have any thoughts about that?

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  2 года назад +1

      You can't do that. Extend approach is not that popular in Angular at all. Typically you just inject services and use them.

  • @ali.shahnawaz
    @ali.shahnawaz 2 года назад

    Awesome content on unsubscribe

  • @austinZen8800
    @austinZen8800 2 года назад

    you'll need a super() call in the component's constructor using / extending this class, otherwise TS will complain?

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  2 года назад

      You are totally right. If you need to do anything in contructor you must call super.

  • @roman-tp6sd
    @roman-tp6sd 2 года назад

    You re the best! Tnxx!

  • @rohit36910
    @rohit36910 11 месяцев назад

    Premium content, useful information. Thank you

  • @space-waves
    @space-waves 7 месяцев назад

    Wait what? I was sure the component is destroy when not in the view anymore and by consequence all subscribe are unsubscribed…

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  7 месяцев назад

      Destroying doesn't have anything to do with the in view or not. Also you need to unsubscribe manually.

  • @RayZde
    @RayZde 2 года назад

    why don't we just use a promise for queries? this sounds like a potential problem in your app to troubleshoot.

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  2 года назад

      It's architecture of Angular team. I didn't have any problems or need to use promises in Angular.

  • @letok2871
    @letok2871 2 года назад

    Крутотень)

  • @lindermannla
    @lindermannla 2 года назад

    Monster! 😂

  • @iukys3889
    @iukys3889 Год назад

    I don’t feel like the video is useful at all, this can be found in angular doc and this is far from real life situation (interval really ? ..)

  • @mkrzyzowski
    @mkrzyzowski Год назад

    Last one approach is nice but it does not allow to use "ngOnDestroy" in the "Postscomponent" as it is already declared in "Unsub".

    • @mkrzyzowski
      @mkrzyzowski Год назад

      but we can add "public unsubscribe(): void {" in "Unsub" and call it from "public override ngOnDestroy() {", "this.unsubscribe();" to solve it.

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  Год назад

      exactly