Learn Angular Signals - The Future of State Management

  Рет қаралды 23,526

Monsterlessons Academy

Monsterlessons Academy

Күн бұрын

Пікірлер: 64
@MonsterlessonsAcademy
@MonsterlessonsAcademy 25 күн бұрын
WATCH NEXT: Angular Interview Questions and Answers - Dominate Your Next Interview - kzbin.info/www/bejne/a3LCin6ii7yAhtEsi=2DCn7yspEAAJ2H6l
@gowthamp5612
@gowthamp5612 Жыл бұрын
For me,signal just looks like useState and useEffect in React,with more functionalities like mutable and compute.But,in my opinion change detection will easier and quicker by signals.
@MonsterlessonsAcademy
@MonsterlessonsAcademy Жыл бұрын
I agree. Looks like copy pasting ideas from React
@andres3665
@andres3665 11 ай бұрын
They are copying and pasting from solid.js@@MonsterlessonsAcademy
@Brendan2Alexander
@Brendan2Alexander Жыл бұрын
Helpful and concise thank u!
@MonsterlessonsAcademy
@MonsterlessonsAcademy Жыл бұрын
Glad it was helpful!
@waelm.elsaid295
@waelm.elsaid295 8 ай бұрын
Thank you very much for your valuable content , but i need to ask a question regarding the computed and specially for the example you used what the different between calling usersTotal() in the html template and calling users().length directly ? is there any advantage of using computed in this case ? and thanks again
@MonsterlessonsAcademy
@MonsterlessonsAcademy 8 ай бұрын
In this case not really. computed is some logic that you want to compute. Reading length has no logic so you don't need computed. It is also a good place for logic which you don't want to write in html.
@d1ge
@d1ge 7 ай бұрын
Signals are not just easier to grasp, than RXJS, but they are also closer to what's actually happening under the hood. - the fact alone, that your effect methods now can run sync instead of async, without frankensteining your ngOnChange method, is a feature in itself
@MonsterlessonsAcademy
@MonsterlessonsAcademy 6 ай бұрын
Yeap
@tarquin161234
@tarquin161234 4 ай бұрын
At the moment I just don't really like the idea of making async things sync just by using toSignal with an arbitrary initial value. Sometimes, effects don't work as desired/expected when this arbitrary value comes in as the first value before the database value. For example, my effect needed to calculate a default value for a form field when it was null, so I did it in an effect, but the problem was this arbitrary value came in before the db value and so the wrong value was assigned to the form field. In my opinion, it is better to just wait for the database value, which means using rxjs instead of a signal. In my opinion it is better to use rxjs for async stuff, and use signals for sync stuff if you want, but for me I find it simpler to just use rxjs for everything.
@farrukhmomin5291
@farrukhmomin5291 Жыл бұрын
I really don't like the esthetics of signals. Code separation which ngrx offers make code base really clean. I hope angular team comes up with something which makes code looks cleaner.
@MonsterlessonsAcademy
@MonsterlessonsAcademy Жыл бұрын
You can continue use ngrx and they will use signals underneath.
@bullettime2808
@bullettime2808 8 ай бұрын
you are comparing apples with oranges
@jsiahaan
@jsiahaan Жыл бұрын
Great video! Thanks
@MonsterlessonsAcademy
@MonsterlessonsAcademy Жыл бұрын
You're welcome!
@MultiWarrr
@MultiWarrr Жыл бұрын
Sorry for out of context question, in ngrx can and should i update state from the backend service without any actions dispatched from from user (commercial platform) Thanks in advance
@fastestnotes1046
@fastestnotes1046 8 ай бұрын
I don't get it. Why can't we just use the ngModel directive with events? It doesn't make sense to use a variable like title as a method call.
@MonsterlessonsAcademy
@MonsterlessonsAcademy 8 ай бұрын
ngModel works through change detection cycle and signals not. Change detection cycle is slow on big apps and signals not.
@L-Lesiv
@L-Lesiv 8 ай бұрын
Why do we need [value]="title()" in html if we change signal in event function?
@MonsterlessonsAcademy
@MonsterlessonsAcademy 8 ай бұрын
Because we need to render a value in the input
@ajinkyachanshetty
@ajinkyachanshetty 6 ай бұрын
Amazing content!
@MonsterlessonsAcademy
@MonsterlessonsAcademy 6 ай бұрын
Glad you think so!
@nandhakumarappusamy9457
@nandhakumarappusamy9457 5 ай бұрын
Very helpful
@MonsterlessonsAcademy
@MonsterlessonsAcademy 5 ай бұрын
Glad you think so!
@mugatu2017
@mugatu2017 Жыл бұрын
Excellent explanation
@MonsterlessonsAcademy
@MonsterlessonsAcademy Жыл бұрын
Glad you like it!
@mugatu2017
@mugatu2017 Жыл бұрын
@@MonsterlessonsAcademy we have in rxjs multicast operators (BehaviorSubject - ReplySubject - AsyncSubject, EventEmitter) son we can achieve exactly the saqme as Signals
@thorstenschmidt21
@thorstenschmidt21 Жыл бұрын
Hi, exists something like a benchmark? I learned that we should not call functions in Angular because it will make the app significantly slower. But with the signal you added a function to the view. How fast is it compared to older approaches?
@MonsterlessonsAcademy
@MonsterlessonsAcademy Жыл бұрын
I didn't see any benchmarks or real app comparisons yet.
@baluditor
@baluditor Жыл бұрын
Calling signals is not like calling a function, it's perfectly safe to do. Calling a function is discouraged due to Angular's change detection mechanism, but signals won't trigger change detection like functions would in the template.
@thorstenschmidt21
@thorstenschmidt21 Жыл бұрын
@@baluditor thank you, I had a chance to look into angular 16 now too and I think you are right.
@LukeAvedon
@LukeAvedon Жыл бұрын
Wow. Hey, really likeing your paid course my guy.
@MonsterlessonsAcademy
@MonsterlessonsAcademy Жыл бұрын
Glad to hear that!
@riatec6741
@riatec6741 Жыл бұрын
Can we cancel a signal that has been created?
@MonsterlessonsAcademy
@MonsterlessonsAcademy Жыл бұрын
Why do you need to do that? It is not a subscription. It's the same like creating a subject. I doesn't cause performance problems.
@nobrainer616
@nobrainer616 5 ай бұрын
@@MonsterlessonsAcademywhy not just use the BehaviorSubject instead of signal? is there some other cases of signal usage that I’m missing?
@maciej12345678
@maciej12345678 9 ай бұрын
@effectssss
@SteDeus
@SteDeus Жыл бұрын
The video was very clear! I just didn't understand how effect works: how does it know to trigger when title is changed and not when users does? Does it trigger every time any signal change?
@MonsterlessonsAcademy
@MonsterlessonsAcademy Жыл бұрын
As for now effect is called if any signal changes. I would like to see some api to trigger it only for specific signal similar to dependencies of useEffect in react
@luczztem
@luczztem Жыл бұрын
@@MonsterlessonsAcademy wow that's very weird...
@SteDeus
@SteDeus Жыл бұрын
@@MonsterlessonsAcademy Oh I see, I hope they give us a way to specify which effect should trigger or we have to make some custom shenanigans 😅
@baluditor
@baluditor Жыл бұрын
Effects will only run if any of their dependencies change, from the docs: Effects always run at least once. When an effect runs, it tracks any signal value reads. Whenever any of these signal values change, the effect runs again. Similar to computed signals, effects keep track of their dependencies dynamically, and only track signals which were read in the most recent execution.
@1306dk
@1306dk Жыл бұрын
I always look forward to your content. Any plans on getting in testing in Angular with Jest for example?
@MonsterlessonsAcademy
@MonsterlessonsAcademy Жыл бұрын
Thank you for the idea. I will add it to the list of future videos.
@anutaNYC
@anutaNYC 7 ай бұрын
Target with a g as in girl not j
@xxRAP13Rxx
@xxRAP13Rxx 2 ай бұрын
Thank you! Amazing video! What is the difference between update() and mutate()? Does update() trigger change detection in the current component while mutate() does not?
@xxRAP13Rxx
@xxRAP13Rxx 2 ай бұрын
Actually, I can't seem to find mutate() in the Angular docs anywhere. I can only find update(). Did they remove mutate()?
@MonsterlessonsAcademy
@MonsterlessonsAcademy 2 ай бұрын
You are right. They removed mutate (which is awesome)
@ismailuwair187
@ismailuwair187 6 ай бұрын
is it better in general to use signals instead of variables that are binded to UI for example?
@MonsterlessonsAcademy
@MonsterlessonsAcademy 6 ай бұрын
Yes it is better.
@mahdikamran8061
@mahdikamran8061 10 ай бұрын
Hello, Thanks for your videos. I have a question, are you from Germany? where are you from?
@MonsterlessonsAcademy
@MonsterlessonsAcademy 10 ай бұрын
Hi, originaly from Ukraine but last 8 years living in Hamburg.
@L-Lesiv
@L-Lesiv 8 ай бұрын
So signals need only for not enter in life cycles, they are not accesible from other components like subjects?
@MonsterlessonsAcademy
@MonsterlessonsAcademy 8 ай бұрын
You can put them in service and reuse everywhere
@yaghuzt
@yaghuzt Жыл бұрын
Hi, I am a bit confused, to me it looks like ngModel, whats the difference?
@MonsterlessonsAcademy
@MonsterlessonsAcademy Жыл бұрын
It doesn't trigger Angular change detection cycle. It is extremely fast in big apps
@paweliszewski6575
@paweliszewski6575 Жыл бұрын
hello, what text editor are you using? love the channel
@MonsterlessonsAcademy
@MonsterlessonsAcademy Жыл бұрын
It's Vim here is my video about it kzbin.info/www/bejne/j6Ovmqidec12q80
@pietrosmusi1409
@pietrosmusi1409 Жыл бұрын
they are copying from react and vue lol
@MonsterlessonsAcademy
@MonsterlessonsAcademy Жыл бұрын
Yeap a bit
@chrisburd9751
@chrisburd9751 10 ай бұрын
I still think Rxjs is better than signals.
@MonsterlessonsAcademy
@MonsterlessonsAcademy 9 ай бұрын
They are different
@chrisburd9751
@chrisburd9751 9 ай бұрын
@@MonsterlessonsAcademy I disagree - they both do state management, they both can interconnect components, and they both stream data the same way. In fact they are really no different than a behavior subject.