Тёмный

Angular Signals: What? Why? and How? 

Deborah Kurata
Подписаться 16 тыс.
Просмотров 63 тыс.
50% 1

Опубликовано:

 

29 сен 2024

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 232   
@184Simon
@184Simon Год назад
Deborah, we are so blessed to have you in the Angular community!!!
@deborah_kurata
@deborah_kurata Год назад
Thank you so much! 🙏
@linamariabeltrandurango
@linamariabeltrandurango 10 месяцев назад
@@deborah_kurata I sincerely appreciate your time and knowledge you shared.
@thenatedoggchannel9719
@thenatedoggchannel9719 6 месяцев назад
Spot on. As a constantly struggling Angular adopter, Deborah has been one of the most valuable resources I've had. Her Plural Sight courses are phenomenal.
@everyonesview
@everyonesview 2 месяца назад
It's unbelievable the time and effort you put in your tutorials, Deborah. We appreciate you - always!
@deborah_kurata
@deborah_kurata 2 месяца назад
Thank you so much! 😊
@dixavier27
@dixavier27 3 месяца назад
AMAZING!
@deborah_kurata
@deborah_kurata 3 месяца назад
Thanks! 😊
@mugatu2017
@mugatu2017 Год назад
thanks, what about the new life cycle hooks?
@deborah_kurata
@deborah_kurata Год назад
I didn't cover them yet because AFAIK, they aren't all implemented yet. They are still in RFC (Request for Comment) stage. You can find out more about the proposed lifecycle changes here: github.com/angular/angular/discussions/49682 under the topic of "Component lifecycle and effects" NOTE: I *did* cover `effect()` in the video which is also discussed in this section. NOTE: Even though all of the lifecycle hooks are shown in the above referenced document as functions within the constructor, many of them can be defined declaratively as shown with the `effect()` in this video.
@mugatu2017
@mugatu2017 Год назад
@@deborah_kurata thanks Debora!!
@olivierboisse1678
@olivierboisse1678 4 месяца назад
9:58 this is not true. Signals will only notify its LIVE consumers (i.e. component templates or effects). For others situations the link between producer and consumer is owned by the consumer, thus the consumer value will be updated the next time it is read, not when the producer changes its value.
@joeyvico
@joeyvico 10 месяцев назад
Oh my goodness! Aren't you the best Angular tutor on youtube?! Honestly, you clearly standout. Please continue with your teaching style. Thank you Deborah
@deborah_kurata
@deborah_kurata 10 месяцев назад
Wow, thank you! That is very kind of you to say! 😊
@_khaledg
@_khaledg Год назад
Thank you Deborah, you are so talented at explaining concepts. Would love to see videos related to standalone APIs and non-destructive hydration as well.
@deborah_kurata
@deborah_kurata Год назад
I'll add standalone APIs to my list! 😀 I don't have much experience with SSR, so I'm not that knowledgeable in its hydration nor how it's changing. So I may not be able to tackle that one any time soon. :-)
@meeeh
@meeeh Год назад
Oh yesss! I'm so happy you made a video about signals. Everything seems so much easier when you explain it! That's a rare talent. I'm a big fan 😊
@deborah_kurata
@deborah_kurata Год назад
Thank you so much! Great to hear it was helpful! 😊
@vidyas1545
@vidyas1545 Год назад
I second this !!! Why I didn’t know about your courses earlier 😊
@nikhilgoyal007
@nikhilgoyal007 2 месяца назад
I absolutely love your way of teaching. I can only guess how much effort you have to put in to make it this tasty for the rest of us. Bow of respect. Kind Regards.
@deborah_kurata
@deborah_kurata 2 месяца назад
Thank you very much! Yes, it takes several days to put one of these together. So glad to hear that the videos are useful!
@makacoder
@makacoder 10 месяцев назад
Signal is I think a borrowed idea from knockoutjs (it's called observable in knockoutjs). Computed is a knockoutjs feature as well
@deborah_kurata
@deborah_kurata 10 месяцев назад
It seems so. Have you see this? dev.to/this-is-learning/the-evolution-of-signals-in-javascript-8ob
@fahadgaliwango4502
@fahadgaliwango4502 Год назад
Signal is value + notification change. This will bring less boilerplate code with the internal reactive code of the component .instead of observable which requires subscription each time value is needed. Thanks @Deborah 🎉
@deborah_kurata
@deborah_kurata Год назад
Yep! But you'll probably still see Observables in services to handle http requests and other async operations.
@kudorgyozo
@kudorgyozo 5 месяцев назад
what's the difference between update and set?
@deborah_kurata
@deborah_kurata 5 месяцев назад
Set just assigns a new value. this.filterSignal.set(newFilter); Update gives you the existing value, so you can manipulate it. this.filterSignal.update(currentFilter => currentFilter.toLocalLowerCase()); Did that help answer the question?
@mikaduchna1987
@mikaduchna1987 7 месяцев назад
I was just wandering... why using signal with array in ngFor in this case? Isn't that useful where we have more dynamically changing list of values?
@mansoorabdullah
@mansoorabdullah Год назад
2:12 the computation should be, exPrice = price * qty not exPrice = price * quantity
@deborah_kurata
@deborah_kurata Год назад
Yep. You are correct. Thanks for pointing that out! AFAIK, there is no way to edit a YT video once it's been posted. But I can add it to the video notes. Thanks again!
@mansoorabdullah
@mansoorabdullah Год назад
@@deborah_kurata Yes, you can edit a RU-vid video that you have uploaded, as long as you are signed in to your RU-vid account. Here are the steps to edit your video: Sign in to your RU-vid account and go to your channel's Video Manager. Find the video that you want to edit and click on the Edit button. You will be taken to the Video Editor, where you can trim, split, add or remove sections, add music, and make other changes to your video. After you have made your edits, click on the Save button to save the changes. Once you have saved the changes, the edited video will be processed and replaced on RU-vid. Please note that the video URL and statistics associated with the video will remain the same. It's important to note that if your video has already been monetized, re-uploading an edited version may affect your monetization status. Also, if the video has been live for a while and has accumulated views, editing it may affect its search rankings and visibility. So, it's a good idea to carefully consider the changes you want to make before editing a video that has already been published.
@deborah_kurata
@deborah_kurata Год назад
I see options to: - Trim & Cut - Blur - Audio - End screen - Info cards I don't see any option to actually *add* anything. So it looks like I could cut out the error, but not replace it with a correction. AFAIK, I can't even add a callout pointing to the typo. Since this error really doesn't impact the training in the video on signals, it doesn't seem worth trying to fix it. I did add it to a NOTE in the description. Thanks!
@vadimchilinciuc8296
@vadimchilinciuc8296 11 дней назад
Thanks ,for your nice videos !
@sudhansusatyam5835
@sudhansusatyam5835 7 месяцев назад
You are the best tutor I found so far... But how? Give some tips
@sepidehmasoomi7044
@sepidehmasoomi7044 Год назад
Wow, This video is absolutely awesome! The content is explained so clearly and straightforwardly. Thank you!
@deborah_kurata
@deborah_kurata Год назад
So glad to hear it's useful! 😊 Thanks!
@wathanaphon1
@wathanaphon1 Месяц назад
Hi , I hope this message finds you well. I am currently working on a project using PrimeNG and I need some assistance. Could you please guide me on how to configure the PrimeNG Calendar to display the year in the Buddhist calendar (B.E.) instead of the Gregorian calendar? Your expertise and help would be greatly appreciated. Thank you in advance for your support. Best regards,
@deborah_kurata
@deborah_kurata Месяц назад
I have not used PrimeNG, so don't have the expertise to help you with that. Maybe try PrimeNG support or stackoverflow?
@VinitNeogi
@VinitNeogi Год назад
Can't wait for v16 release!
@deborah_kurata
@deborah_kurata Год назад
Agreed! They just announced that it is expected to be released May 3.
@amerispunk
@amerispunk Год назад
I'm a big fan of your Pluralsight courses as well! There are so many of them I feel like I'll never keep up, LOL. I'm hoping that Angular can add these features such as signal, effect and compute without slowing down the responsiveness. I wonder if there are any numbers on that?
@deborah_kurata
@deborah_kurata Год назад
Thank you! 🙏 Signals will improve responsiveness ... especially if you create signals for all of your bound properties and turn on OnPush change detection. In a future version of Angular, signals will improve responsiveness even further by allowing for "zone-less" change detection. (zone.js is what Angular currently uses for change detection)
@pronileston4869
@pronileston4869 Год назад
Love it
@deborah_kurata
@deborah_kurata Год назад
Excellent!
@dozadetrezire7455
@dozadetrezire7455 6 месяцев назад
In Angular 17, the mutate method doesnt work anymore. What's the alternative for it in Angular 17?
@deborah_kurata
@deborah_kurata 6 месяцев назад
Correct. Now you can use the update method instead. I have some examples here: ru-vid.com/video/%D0%B2%D0%B8%D0%B4%D0%B5%D0%BE-wcn_8UnYBEw.html
@davidaimakhede1980
@davidaimakhede1980 10 месяцев назад
Best Signal tutorial i have seen so far! Weldone!
@deborah_kurata
@deborah_kurata 10 месяцев назад
Wow, thanks! Glad it was helpful!
@guilhermelacerda3908
@guilhermelacerda3908 Месяц назад
OMG, what an amazing class! Tks, it helped me a lot! ⭐⭐⭐⭐⭐
@deborah_kurata
@deborah_kurata Месяц назад
So glad to hear that! Thank you!
@raj.blazers
@raj.blazers Месяц назад
One question- Whatever the function that she performed within computed function could be done in the event handler function also right? So, What is the difference?
@deborah_kurata
@deborah_kurata Месяц назад
In a more realistic application, there could be a number of events that could cause the extended price to change. For example, if the user increases the number of items or if the user selects a different item (with a different price). Instead of repeating that code in numerous events, we make the code "declarative" and specify how the variable should change directly when we declare it using a computed property. Another example, if we had a total price that would recalculate if the user changed the shipping location (shipping cost changes), or modified the number of ordered items (quantity changes) or adds/removes items from the list. We wouldn't want repeated code in each of these possible events. Rather, we define how the variable is calculated directly when we declare it. This makes the code less repetitive, more clear, and often easier to read. Often, we use a simple application to demonstrate a technique in order to keep the focus on the technique. But the benefits of the technique are often more obvious as an application gets more full featured/complex. Did that help?
@FredYang
@FredYang 10 месяцев назад
This video shows What and How, but not why. All the example shows here can be replaced with plain out javascript object. How does it improve change detection? Can we remove zone.js with Signal? I didn't see it the demo here.
@deborah_kurata
@deborah_kurata 10 месяцев назад
The why: - Signals provide reactivity. Using computed signals, a value can react to changes in its dependent signals. This allows you to build a shopping cart, for example, that automatically recalculates the extended price, subtotal, taxes, delivery fees, and so on. This makes it much easier to have data react to changes in other data in your application. This functionality could *not* easily be replaced with a plain old JavaScript object. You'd have to build a bunch of setters. - Signals currently provide improved change detection using OnPush. They *will* (in the future) provide for zone-less change detection. But I didn't demo that because that feature is not yet implemented.
@havefun5519
@havefun5519 Год назад
In the same component, The function/requirement could be implemented via existing API only the constructor can't be notified of the update for the variables? Hope for more videos. Thanks.
@deborah_kurata
@deborah_kurata Год назад
Could you elaborate? I'm unclear on your question.
@thedacian123
@thedacian123 Год назад
What's happend woth RX and subscriber/observables then,Are Angular team going to get rid of them?
@deborah_kurata
@deborah_kurata Год назад
Signals are synchronous and primarily for keeping our UI updated with changes to data in our component. RxJS/Observables are for asynchronous operations, such as retrieving data via http. That won't change and won't go away. There will be methods such as fromObservable() that will take an Observable and convert it to a signal for display in the UI. You can think of it more like that signals will replace the async pipe. Like the async pipe, the fromObservable() will automatically subscribe/unsubscribe to the Observable. Does that answer the question?
@musoverda
@musoverda 8 месяцев назад
Are there already any standards (generally accepted rules) for writing variable names for signals?
@deborah_kurata
@deborah_kurata 7 месяцев назад
There have been some discussions about this. I have not seen any generally accepted rule, however. Some devs have been using a suffix (such as countSig), which personally I don't care for. Reminds me of the old Hungarian notation. Some devs have been prefixing it with a $, so $count. Personally, I don't really care for that either. But some developers have found this useful. Someone even suggested double $$, so count$$, which I think could be very confusing. :-)
@deibymontoya9284
@deibymontoya9284 Год назад
What a brilliant way to explain this! I love how you explain each concept wich such a good examples! Thank youuu, now it's very clear to me this exciting mew feature!
@deborah_kurata
@deborah_kurata Год назад
Thank you so much! It's great to hear that the video was useful!
@alexle7895
@alexle7895 Год назад
Would Signals replace NgRx, or it is a completely different feature?
@deborah_kurata
@deborah_kurata Год назад
Signals are completely different from NgRx. Though NgRx has been modified to take advantage of the new signals features. See this: dev.to/this-is-angular/signals-what-this-means-for-ngrx-eho
@raj.blazers
@raj.blazers Месяц назад
Is the mutate method of signal dropped off in V18?
@deborah_kurata
@deborah_kurata Месяц назад
Yes. (Though it was already dropped in v17) The team determined that anything you could do with mutate you could also do with update. So having two and trying to explain when to use one vs the other wasn't worth it. (I wish there was a way to update the YT video to state this. Best I can do is note it in the comments.)
@dreamvallyhasan4807
@dreamvallyhasan4807 6 месяцев назад
Best Angular tutorial ever ..mis we want a large projects using .net core api, angular 17 + RDLC with you ..thanks from the bottom of my heart
@MrKYT-gb8gs
@MrKYT-gb8gs Год назад
I had to use a differ to detect change in an object (dictionary) type variable. Does signal detect change in object without extra bits of code?
@deborah_kurata
@deborah_kurata Год назад
You shouldn't need extra code. Could you do a stackblitz to demo your scenario?
@rs4267
@rs4267 9 месяцев назад
Thanks i've understand the concept and see how much sigals can be usefull
@deborah_kurata
@deborah_kurata 9 месяцев назад
Glad it was helpful! Thanks for watching!
@bijoyalfred87
@bijoyalfred87 Месяц назад
I request you to kindly add videos about unit testing signals
@deborah_kurata
@deborah_kurata 26 дней назад
Great idea. I keep expecting to see more guidance on testing signals coming from the Angular team ... so I've been waiting for that.
@mqb268
@mqb268 Год назад
Thank you Deborah for updating. Your videos are very easy to understand and useful.
@deborah_kurata
@deborah_kurata Год назад
Thank you for the kind words.🙏 Glad you found the video useful!
@MohamedHassan-hk6dh
@MohamedHassan-hk6dh 6 месяцев назад
could you make a video about input signal with data from the server ? and thanks in advance
@deborah_kurata
@deborah_kurata 6 месяцев назад
The purpose of a "signal input" is to pass data from a child component to a parent component. Or do you mean a signal set of data retrieved from the server? If you mean the later, I have several videos on using Angular signals with RxJS (to retrieve data from the server). Consider starting with this one: ru-vid.com/video/%D0%B2%D0%B8%D0%B4%D0%B5%D0%BE-MQwn1cGJ5z0.html
@VladiGuitar87
@VladiGuitar87 5 месяцев назад
Hey. Thanks a lot four your work! You explain the topic very well!
@deborah_kurata
@deborah_kurata 5 месяцев назад
Hey! Thank you for the kind words! 😊
@deliailetchi9740
@deliailetchi9740 Год назад
❤So good to find these tutorials on RU-vid!
@deborah_kurata
@deborah_kurata Год назад
Glad they were useful! Thank you! 🙏
@raghavendra6978
@raghavendra6978 Месяц назад
This was really a awesome way of teaching, thanks :)
@deborah_kurata
@deborah_kurata Месяц назад
Glad it was helpful! Thank you! 😊
@augustincalin
@augustincalin Год назад
Thanks for explaining this -- as always, it's a pleasure to learn from you. Small tip: in VS Code, and also in StackBlitz, when you want to replace the same value in multiple places (like you did for the Angular version), you can select one of the instances and press Shift + Ctrl + L --> it will select all of them. Then, as soon as you start typing the new value, it will be done at once, changing all that instances.
@deborah_kurata
@deborah_kurata Год назад
Thank you for the kind words. 😀 Great tip. I knew it worked in VS Code, I didn't realize that Stackblitz supported the feature as well. (I guess I should have known as I believe Stackblitz is VS Code on the inside.) Thank you so much for sharing this tip! 🙏
@pavankumarrampathati7818
@pavankumarrampathati7818 3 месяца назад
Thank you very much for let us know🎉🎉🎉🎉🎉🎉
@deborah_kurata
@deborah_kurata 3 месяца назад
Great! Hope it's useful for you!
@winnemucca-sk5392
@winnemucca-sk5392 Год назад
Thank you for the course. I used to follow all of your courses on pluralsight. Is this channel your main source of content now?
@deborah_kurata
@deborah_kurata Год назад
I still have courses on Pluralsight. And I'm working on a new Pluralsight course now. But most of my new content will be via this channel.
@danielchirinosr
@danielchirinosr Год назад
hi Deborah, how can I update a signal from another component?
@deborah_kurata
@deborah_kurata Год назад
Move the signal to a service, inject the service, and then it can be updated from any component.
@MohamedHassan-hk6dh
@MohamedHassan-hk6dh 8 месяцев назад
thanks for your effort , i hope to see videos related to micro frontend in angular
@deborah_kurata
@deborah_kurata 7 месяцев назад
Thanks for watching! I'll add that to my list. Thanks!
@vd2828
@vd2828 7 месяцев назад
Awesome video. Thank you so much
@deborah_kurata
@deborah_kurata 7 месяцев назад
Great to hear! Thanks!
@MostafaMohamed-uw4lf
@MostafaMohamed-uw4lf 10 месяцев назад
you are so talented, awesome explaination, thanks so much. do you have courses for design pattern / algorithm / data structure?
@deborah_kurata
@deborah_kurata 10 месяцев назад
Thank you so much! I had given thought to doing content on data structures, but I wasn't sure how much interest there would be in those topics. Do you have specific topics you'd like to see?
@MostafaMohamed-uw4lf
@MostafaMohamed-uw4lf 6 месяцев назад
i am not sure, but i believe it would be amazing 1. data structure and algorithm. 2.design pattern.
@bojanasamardzioska3040
@bojanasamardzioska3040 Месяц назад
thanks a lot! great explanations!
@deborah_kurata
@deborah_kurata Месяц назад
Glad it was useful! Thank you for watching!
@NishvanthD
@NishvanthD 3 месяца назад
If i used the signal getter directly in the template will it leads to multiple calls in angular ?.//we should avoid calling methods/getter from our template because the method will be called every time change detection runs right ?
@deborah_kurata
@deborah_kurata 3 месяца назад
The signal getters are no different from accessing a normal property value. The general rule of not calling methods/getters from the template was primarily to prevent running code within the getter or method. For a signal getter, we can't add any code. If we use a computed signal to add some code, then the value is memoized, so it isn't re-executed/recalculated unless the related data changes. The Angular team sees signals as the future of very efficient change detection, so I'm sure they've worked diligently to ensure the signal getters are efficient. Does that answer the question?
@NishvanthD
@NishvanthD 3 месяца назад
@@deborah_kurata Thankyou Very much
@timothyasigbey3304
@timothyasigbey3304 Год назад
It looks more like mobx is there any possible use case to use signals with ngrx. Nice video by the way. Well explained.
@deborah_kurata
@deborah_kurata Год назад
Check this out: dev.to/ngrx/announcing-ngrx-v16-integration-with-angular-signals-functional-effects-standalone-schematics-and-more-5gk6
@timothyasigbey3304
@timothyasigbey3304 Год назад
thank you@@deborah_kurata
@erfanfarhadi
@erfanfarhadi Год назад
Hi Deborah thank you for your wonderful video there is a misunderstanding for me about the update and mutate could you describe what is difference between update and mutate?
@deborah_kurata
@deborah_kurata Год назад
Update changes the signal itself. In this example we are removing the 5 from the signal and replacing it with a 10. counter = signal(5); constructor() { this.counter.update((value) => value * 2); } The mutate changes one of the signal elements or properties without changing the signal itself. In this example, we aren't replacing the signal. It's still an array of 6 numbers. Instead, we are mutating the first element of the array and changing it to 100. numbers = signal([0, 1,2,3,4,5]); constructor() { this.numbers.mutate(value => value[0] = 100); } Note that in most cases, you can achieve the same result of the mutate with an update if you want to replace the entire array. The following code achieves the same as the mutate shown above: this.numbers.update((value) => [100, ...value]) But it marks the entire array as changed instead of just one array element. How that might affect change detection is not clear at this point because the Angular team has not yet implemented specialized change detection for signals.
@erfanfarhadi
@erfanfarhadi Год назад
@@deborah_kurata Thank you for your valuable response. The earth needs people like you☘️
@daniilevsienko4060
@daniilevsienko4060 Год назад
Thank you for the video! If we have sequentially this.quantity.set(5) and this.quantity(42) ru-vid.com/video/%D0%B2%D0%B8%D0%B4%D0%B5%D0%BE-oqYQG7QMdzw.html why don't effect() display intermediate value? Is there an internal timer?
@deborah_kurata
@deborah_kurata Год назад
Thank you for watching! JavaScript is single threaded. It won't execute the effect code until the prior code block that sets the quantity is complete. Then when the effect does run, reading the signal *only* reads the current value, not any prior value.
@daniilevsienko4060
@daniilevsienko4060 Год назад
@@deborah_kurata I see, thank you! Sorry for stupid question:)
@deborah_kurata
@deborah_kurata Год назад
@@daniilevsienko4060 No problem. And, as they say, there are no stupid questions! 🙂
@jitheshkramesh
@jitheshkramesh 8 месяцев назад
Thanks for the tutorial. Once the page gets forcefully refreshed (F5), all the signal/subject values are getting cleared. How to fix this ? . Please help.
@deborah_kurata
@deborah_kurata 8 месяцев назад
A refresh reloads the entire application and all of its internal state. There is no way to prevent that. If you need to retain the values on a reload, you need to write the values out to somewhere (a backend server or local storage) and then re-read the values in when the application is reloaded.
@jitheshkramesh
@jitheshkramesh 8 месяцев назад
@@deborah_kurata when I tried to update Signal at effect getting error message like this. please suggest. Writing to signals is not allowed in a `computed` or an `effect` by default. Use `allowSignalWrites` in the `CreateEffectOptions` to enable this inside effects.
@deborah_kurata
@deborah_kurata 6 месяцев назад
Yeah, the recommended practice is to not update a signal in an effect because it could potentially cause an infinite loop. If you really need to, you can do exactly as the error message says and use the effect options to set allowSignalWrites.
@chuonchuon7386
@chuonchuon7386 11 месяцев назад
your videos are great. thank you. 😀
@deborah_kurata
@deborah_kurata 11 месяцев назад
Glad you like them! Thank you!
@NewdevHajjouji
@NewdevHajjouji Год назад
Thank you well explaind
@deborah_kurata
@deborah_kurata Год назад
Thank you! 🙏🏼
@marcosjrs
@marcosjrs 8 месяцев назад
Thank you very much, Deborah. Your videos are very helpful, even for people who don't speak English very well. Everything is very well explained, step by step.
@deborah_kurata
@deborah_kurata 8 месяцев назад
So glad to hear they are useful. Thank you! 😃
@CarlosRivadeneiraZ
@CarlosRivadeneiraZ 10 месяцев назад
I'm feeling like I'm in plurlsight, thanks for share your knowledge Deborah
@deborah_kurata
@deborah_kurata 10 месяцев назад
Thank you for watching!
@celikart
@celikart Год назад
Hi Deborah, thank you so much for sharing. I have few questions; what about unsubscrıbing? Does ıt keep lıstening always: when to use sıgnal or observable (RxJs)? why Signal came up , because of less syntax?
@deborah_kurata
@deborah_kurata Год назад
There is no "subscribe", so no need to "unsubscribe". The component signals will keep listening until the component is destroyed. If the signal is in a service, the service will keep listening until that service's injector is destroyed. Signals are primarily for managing change detection for the UI. So here's the flow: - User kicks off an operation (such as selecting a customer from a list). - Action is processed in an event handler (like it is now), something like onCustomerSelected() that is called via event binding in the template. - The action may kick off an async process in a service, such as retrieving data based on that Id. That will continue to be done with RxJS/Observables. - The resulting data could be returned from the service as a signal. - The signal is bound to the UI, so the data appears to the user. The only real difference from what we do now is that instead of the service returning an Observable, it could return a Signal. That could be bound directly in the UI instead of needing an async pipe. The first part of the video attempts to explain why ... to provide more reactive programming (computed() for example) and to provide improved change detection. Does that answer the questions?
@prathmeshjoshi8179
@prathmeshjoshi8179 11 месяцев назад
Thanks a lot Deborah for this amazing video. Perfectly explained.
@deborah_kurata
@deborah_kurata 10 месяцев назад
Glad you enjoyed it! Thanks for watching!
@GilbertoAlbino
@GilbertoAlbino 6 месяцев назад
Hi Debora, hope you are fine. Thanks for being so respectful with so well spoke and pronounced English. Most popular RU-vidrs actually speak so fast that they seem to be talking to walls. For people that don't have English as a frist Language, listening to them is just an activity of entertainment, but listening to people like you, is a profound and spectular oportunity to learn and grow. Thanks for being so respectful not just with the so carefully and well-prepared work, but with quality knowledge you have!
@deborah_kurata
@deborah_kurata 6 месяцев назад
Thank you so much!
@zoltarianie
@zoltarianie Год назад
stop buying comments!!!
@deborah_kurata
@deborah_kurata Год назад
Is that a thing? Not sure of your point?
@raj.blazers
@raj.blazers 2 месяца назад
Is it advisable to update a signal within computed function or an effect?
@deborah_kurata
@deborah_kurata Месяц назад
In general, the recommendation is not to. But for effects, there may be times we don't have another option. So take care and consider using untracked where it makes sense.
@raj.blazers
@raj.blazers Месяц назад
@@deborah_kurata If i select an value from dropdown, and the component property 'currentSelectedItem' gets updated, I need to call an api which I am currently calling in the event handler function. Can I move this api call to effect? (But I want to make sure the effect runs only when the dependent variable 'currentSelectedItem' updates) In general, can I use it like useEffect(() => {...some functionality}, [depVar1, depVar2]); which can be done in React?
@deborah_kurata
@deborah_kurata Месяц назад
The current recommendation is to not use effect for async operations. I assume your API call is async? The team is still working on effect (it's still in developer preview) and we hope that some of these issues will be resolved. See this for more information: angular.dev/guide/signals#effects
@YesDiscovery
@YesDiscovery 2 месяца назад
Thank you for your clear and concise explanations. You make Angular concepts easy to understand.
@deborah_kurata
@deborah_kurata 2 месяца назад
Glad it was useful! Thank you!
@im4555
@im4555 Год назад
Thanks very much Deborah for these tutorials - I have one quick question if you don't mind: Is exPrice recomputed on the change to its dependent signals or when it is accessed by the template (which is re-rendered based on other signals)? Thanks!
@deborah_kurata
@deborah_kurata Год назад
Thank you for watching. Any computed is calculated the first time it's read. The value is then memorized and reused whenever it's read again. When any dependent signal changes, the next time the computed is read it is recalculated. That new value is then memorized and reused whenever it is read again. Is that what you were asking?
@AmmarTheTrainer
@AmmarTheTrainer 8 месяцев назад
best explanation of signals so far... thank-you miss @Deborah Kurata for sharing with us..
@deborah_kurata
@deborah_kurata 8 месяцев назад
So glad it was helpful! Thanks for watching!
@pedromoraes2129
@pedromoraes2129 9 месяцев назад
Signals seemed to me like angular is taking some lessons within react 😅 pretty amazing indeed. I worked a few years with Angular, but nowadays I'm working mostly with nextjs and it feels good to see my old boy getting these nice features.
@deborah_kurata
@deborah_kurata 9 месяцев назад
Yep. They are definitely nice features!
@AntonioSantana-ll8il
@AntonioSantana-ll8il Год назад
Terrific explanation!! thanks, i can't wait to see more content, Greetings from Colombia!
@deborah_kurata
@deborah_kurata Год назад
Greetings! Thank you for the kind words!
@vidyas1545
@vidyas1545 Год назад
Hi Deborah , I see signals to be so similar to behavior subjects !! Does this mean Angular is eventually trying to get rid of zone.js?
@deborah_kurata
@deborah_kurata Год назад
Yes ... eventually... that's one of the goals.
@SonNguyen-lw9nj
@SonNguyen-lw9nj Год назад
Thanks so muck
@deborah_kurata
@deborah_kurata Год назад
Thank you for watching!
@rgarafulicm
@rgarafulicm 2 месяца назад
This is pure gold, Deborah. Congrats!
@deborah_kurata
@deborah_kurata 2 месяца назад
Thank you!
@pashabolokhov
@pashabolokhov 10 месяцев назад
Singular Angles
@deborah_kurata
@deborah_kurata 10 месяцев назад
😄
@murilomelo6752
@murilomelo6752 Год назад
Instant subscription! What a beautiful way to explain.
@deborah_kurata
@deborah_kurata Год назад
😊 Great to hear! Thank you so much!
@wonsupjung2527
@wonsupjung2527 Год назад
As you are teaching, using RxJS in programming makes the code simpler, more readable, and easier to maintain. However, after discovering the Signal feature recently introduced in Angular, I realized what an amazing technology it is. Through your lectures, I learned that it can make programs even more elegant and improve readability. Once again, thank you for creating such valuable lectures.
@deborah_kurata
@deborah_kurata Год назад
I'm so glad to hear that these videos have been useful. Thank you for watching!
@fieryscorpion
@fieryscorpion 9 месяцев назад
Wow. That was amazing. Concise and crystal clear!
@deborah_kurata
@deborah_kurata 9 месяцев назад
Great to hear. Thanks!
@jeanfrancoisgamache
@jeanfrancoisgamache Год назад
The best signals explanation that a find, always clear. Thank you
@deborah_kurata
@deborah_kurata Год назад
Thank you so much! 😊
@lingarajsureban9720
@lingarajsureban9720 Год назад
as always very fantastic explanation on this topic... 👋👋
@deborah_kurata
@deborah_kurata Год назад
That is kind of you to say. Thank you.
@fmontes83
@fmontes83 Год назад
Best Signals video ever! Thank you!
@deborah_kurata
@deborah_kurata Год назад
Wow, thanks! Glad to hear it's useful!
@SachalChandio
@SachalChandio Год назад
you are awesome
@deborah_kurata
@deborah_kurata Год назад
😊😊
@demidovmaxim1008
@demidovmaxim1008 Год назад
Thank you! This is the best video about signals I have found
@deborah_kurata
@deborah_kurata Год назад
Thank you so much! 🙏
@leonidesmuguercia4211
@leonidesmuguercia4211 Год назад
The best explanations always come from you!!!!!
@deborah_kurata
@deborah_kurata Год назад
Thank you so much! Great to hear it was useful!
@vaibhavchawla2439
@vaibhavchawla2439 Год назад
Hi Deborah, as always thank you for the detailed explaination. It is always a pleasure to listen to you. However I have a question which isn't related to signal. At @20:01 at line number 14 you used $any(event.target).value. What does this expression specifically $any part means ?
@deborah_kurata
@deborah_kurata Год назад
Thank you for the kind words. The $any requirement is a bit new, starting when Angular defaulted to strict typing throughout. You can find out more about $any here: angular.io/guide/template-typecheck#troubleshooting-template-errors It basically says: "Sometimes a binding expression triggers a type error during AOT compilation and it is not possible or difficult to fully specify the type." and "Use the $any() type-cast function in certain contexts to opt out of type-checking for a part of the expression". This basically generates: (event.target as any).value By casting it to "any", we can access its .value without a type error. Does that help?
@vaibhavchawla2439
@vaibhavchawla2439 Год назад
@@deborah_kurata Thank you very much for the explanation. It is something new that I discovered. 😃😃
@krishnareddyyerram4615
@krishnareddyyerram4615 3 месяца назад
Super
@deborah_kurata
@deborah_kurata 3 месяца назад
Thanks
@tuntunpandit8367
@tuntunpandit8367 Год назад
Please post more videos on angular. Thanks
@deborah_kurata
@deborah_kurata Год назад
I'm hoping to, thanks!
@wiliam334
@wiliam334 Год назад
This the best signals tutorial I have ever seen Thank you Debora
@deborah_kurata
@deborah_kurata Год назад
Wow, thank you! Glad it was helpful!
@ayoubelhayat9650
@ayoubelhayat9650 Год назад
Fantastic explanation 🙌🏻. Thanks a lot Deborah
@deborah_kurata
@deborah_kurata Год назад
Thank you so much! Glad it was useful!
@metric152
@metric152 Год назад
This looks wonderful. Thanks for the clear well explained examples.
@deborah_kurata
@deborah_kurata Год назад
Great to hear. Hope it is useful. Thanks!
@sourishdutta9600
@sourishdutta9600 Год назад
Thank You so much, Mam, That was a very clear view of signals. I have one question How does it improves the changes detection strategy ?? Can you please make one video on this? Thank You.
@deborah_kurata
@deborah_kurata Год назад
Thank you for the kind words. Angular's current change detection uses zone.js. There are several issues with zone.js as outlined here: github.com/angular/angular/discussions/49684 Here's a snippet from the link: "The Zone approach isn't scalable. Zone is based on monkey-patching platform APIs like setTimeout, Promise.then, and addEventListener. This lets Angular know when something has happened in the browser, and we can then schedule change detection to synchronize the UI with any potential model changes. This approach has not scaled well. zone.js must be loaded before the application starts in order to patch its target APIs. This patching operation is not free, both in terms of bytes downloaded and milliseconds of load time. zone.js also has no idea which APIs the application will use, and must patch them just in case. As browsers add more and more APIs, the cost of this patching grows, as does the cost of maintaining zone.js. Another major issue is that some platform APIs, such as async / await, are not monkey-patchable at all, requiring awkward workarounds or forced down-leveling. While we can work to optimize zone.js and reduce these costs, we will never be able to eliminate them completely. Zones are the root cause of many common pain points in Angular. In looking back at 7+ years of Angular history and feedback, we've identified zone.js as a common root cause behind many developer experience or performance challenges. The infamous ExpressionChangedAfterItHasBeenChecked error is often the result of violating Angular's assumptions of how data will flow in your application. Angular assumes that your data will flow from top to bottom along the view hierarchy. This assumption is rooted in how zone.js separates model updates from UI reconciliation, resulting in the potential for "unsafe" model updates. Another issue we've noted is that zone.js can easily overreact to activity in an application, resulting in many unnecessary change detections. Often this results from third-party advertising, marketing, or analytics scripts being initialized in a way that runs their many timers or other actions in the Angular zone. In the worst cases, we've seen applications which do over 1,000+ change detections at startup. It's always possible to write code with performance problems, but zone.js makes it easy to create such issues unintentionally. Developers are opting in to more fine-grained reactivity today Many developers today use state management patterns or libraries that architect their data in a way where they can tell Angular exactly what changed. This usually takes the form of making components OnPush and using Observables together with the async pipe to mark components for check when state they depend on changes. Angular is capable of operating in this mode, but still relies on zone.js for top-down change detection. Thus, developers get some, but not all of the benefits of fine-grained reactivity, and still have to deal with the drawbacks of zone.js."
@sourishdutta9600
@sourishdutta9600 Год назад
@@deborah_kurata Thanks Mam, for your reply I will go through it, What great timing .. Angular team also running live on youtube about the Signal RFC. 🙂 Thank You
@AnthonyDev
@AnthonyDev Год назад
My favorite Angular teacher. ❤ Hey Deborah, what about manage async signals states? Like state is loading, state is success or state has error? Example you want update a vehicle price but to know some discount you need to call a http get.
@deborah_kurata
@deborah_kurata Год назад
Thank you! ☺ Have you seen this video: ru-vid.com/video/%D0%B2%D0%B8%D0%B4%D0%B5%D0%BE-5SD995zKvbk.html Does it answer your question?
@AnthonyDev
@AnthonyDev Год назад
@@deborah_kurata I just watched it! Great explanation and the final code is clear and cleaner. Thanks.
@irinadrozd1573
@irinadrozd1573 8 месяцев назад
Great video Deborah! Thank you
@deborah_kurata
@deborah_kurata 8 месяцев назад
Thanks! And thank you for watching!
@pranambhat7964
@pranambhat7964 Год назад
Big fan here!
@deborah_kurata
@deborah_kurata Год назад
@mikopanjean8756
@mikopanjean8756 Год назад
Great Tutorial, that makes life simpler.
@deborah_kurata
@deborah_kurata Год назад
So great to hear that. Thank you!
@gboyegalawal8881
@gboyegalawal8881 6 месяцев назад
The only video that really explains it well
@deborah_kurata
@deborah_kurata 6 месяцев назад
Thank you so much!
@yuriinadilnyi3029
@yuriinadilnyi3029 Год назад
It's a clearest explanation of signals
@deborah_kurata
@deborah_kurata Год назад
Thank you! 🙏
@sarathlalsaseendran
@sarathlalsaseendran Год назад
Very nice video. I am expecting your full Angular course on Udemy from beginning to advanced. I am sure that will be 5 star rated most popular course in Udemy history.
@deborah_kurata
@deborah_kurata Год назад
Thank you ... but I was not able to get past Udemy's identification requirements. And I've never figured out how to contact an actual person about it. So I have not been able to create a Udemy account. Plus Pluralsight has non-compete agreements, so none of the Pluralsight content can be legally "copied" to other platforms. Pluralsight does plan on retiring my Angular courses sometime later this year (which negates the non-complete), and at that point I plan to post at least some of the content on this channel. Would that be useful?
@sarathlalsaseendran
@sarathlalsaseendran Год назад
@@deborah_kurata That would be really useful. Thank you so much. 😍
@message59
@message59 Год назад
you are a great great teacher deborah 👍 you always break things down in a way that makes it easy to get the bigger picture so just wanted to say thank you for your work 😁
@deborah_kurata
@deborah_kurata Год назад
Thank you so much! Glad it was helpful! 😊
@kjbetz
@kjbetz Год назад
Great stuff, @Deborah! Thanks for the update!
@deborah_kurata
@deborah_kurata Год назад
Thank you! I'll be doing more as more features are added to signals. I'm planning on doing a signal Observable video as soon as the from/to features are implemented in Angular (hopefully v16?)
@julianshaw2000
@julianshaw2000 10 месяцев назад
Best Angular tutor!!!
@deborah_kurata
@deborah_kurata 10 месяцев назад
Thank you for this as well! 😊
@diegoj_c6751
@diegoj_c6751 Год назад
I loved it!
@deborah_kurata
@deborah_kurata Год назад
Excellent! Thanks!
@DoubleRhonRhon
@DoubleRhonRhon Год назад
Hi, thank you . i dont't get why only the last of the 3 '.set(value)' is detected by the effect.
@deborah_kurata
@deborah_kurata Год назад
JavaScript/TypeScript is single threaded. Only one set of code can run at a time. When the event handler code is running, it will continue running until the end. Since all of the event handler code ran *before* the effect code runs, the current value is the last value that was set. When the event handler code execution is complete, other code (such as the effect) can run. The effect is notified that a signal has changed, but is not *given* that changed value. Rather, when the effect executes, it reads the current value from the signal itself. Did that help?
@DoubleRhonRhon
@DoubleRhonRhon Год назад
@@deborah_kurata Ok but i really thought that using 'set', 'update' or 'mutate' would trigger the effect prior (or parallel) to the next line of code. It would be totally reactive in this way. What do you mean by the 'event handler code' : a function called next to the trigger of an event, or a general javascript mechanism ?
@deborah_kurata
@deborah_kurata Год назад
Since JavaScript is single threaded, it will finish executing any code in a function before it runs anything on the "callback queue". By "event handler code", I mean this: onQuantitySelected(qty: number) { this.quantity.set(qty); // Does not "emit" values, rather updates the value in the "box" // The qtyEff effect will not be called until the next tick // It only displays the latest value. this.quantity.set(5); this.quantity.set(42); }
@deborah_kurata
@deborah_kurata Год назад
I found a cool JavaScript flow visualizer here: latentflip.com/loupe Try it out. Try changing the "on" event handler to include code like this: $.on('button', 'click', function onClick() { setTimeout(function timer() { console.log('You clicked the button!'); }, 500); for (let x = 0; x < 10; x++) { console.log(x); } }); You'll see it run through and queue up the setTimeout until the loop at the bottom is finished. *THEN* it will run the callback within the setTimeout and display "You clicked the button!". An effect() is run similarly. Let me know if you found that visualizer useful.
@DoubleRhonRhon
@DoubleRhonRhon Год назад
@@deborah_kurata Ok it displays "you clicked the button!" if we open the console. I searched for it on the web page. i have to keep in mind the "callback queue". Thank you again
Далее
Working with Arrays in Angular Signals
7:49
Просмотров 14 тыс.
How Angular Signals and RxJS Work Together
16:15
Просмотров 29 тыс.
Лайфак года 😂
00:12
Просмотров 63 тыс.
# Rural Funny Life Wang Ge
00:18
Просмотров 673 тыс.
Build Generalized DRY Angular Code with Generics
14:44
RxJS in Angular: Terms, Tips, and Patterns
43:01
Просмотров 31 тыс.
Angular Signals Example - Learn Them by Doing
50:50
Просмотров 12 тыс.
Part 3: Functions
34:04
Просмотров 38
Signals Unleashed: The Full Guide
1:39:24
Просмотров 24 тыс.
Error Handling with Observables
10:19
Просмотров 6 тыс.
Why use Type and not Interface in TypeScript
14:12
Просмотров 208 тыс.
Why Angular Signals? Write Your First Signal
14:25
Просмотров 12 тыс.
Лайфак года 😂
00:12
Просмотров 63 тыс.