{"id":1558,"date":"2023-10-02T05:00:00","date_gmt":"2023-10-02T12:00:00","guid":{"rendered":"https:\/\/www.angulartraining.com\/daily-newsletter\/?p=1558"},"modified":"2023-09-26T14:37:51","modified_gmt":"2023-09-26T21:37:51","slug":"state-management-selector","status":"publish","type":"post","link":"https:\/\/www.angulartraining.com\/daily-newsletter\/state-management-selector\/","title":{"rendered":"State Management: Selector"},"content":{"rendered":"\n<p>We know <a href=\"https:\/\/www.angulartraining.com\/daily-newsletter\/state-management-state-and-store\/\" target=\"_blank\" rel=\"noopener\" title=\"\">how to create a State<\/a> and dispatch actions to update its value. Now let&#8217;s see how to receive updates when the State gets updated.<\/p>\n\n\n\n<p>Most state management libraries provide what is known as <a href=\"https:\/\/www.ngxs.io\/concepts\/select\" target=\"_blank\" rel=\"noopener\" title=\"\">Selectors<\/a>. A Selector query function runs against our State and returns an Observable. For instance, with NgXs, a Selector can be created with the <a href=\"https:\/\/www.ngxs.io\/concepts\/select#select-decorator\" target=\"_blank\" rel=\"noopener\" title=\"\"><code>@Select<\/code> decorator<\/a> as follows:<\/p>\n\n\n<div class=\"wp-block-image\">\n<figure class=\"aligncenter size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"543\" height=\"95\" src=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-58.png\" alt=\"\" class=\"wp-image-1559\" srcset=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-58.png 543w, https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-58-300x52.png 300w\" sizes=\"auto, (max-width: 543px) 100vw, 543px\" \/><\/figure>\n<\/div>\n\n\n<p><\/p>\n\n\n\n<p>The above code creates an Observable that returns any value update in <code>state.currencyInfo<\/code>. If you don&#8217;t like decorators, you can also use the <code>select<\/code> function from the Store service:<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"1014\" height=\"52\" src=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-59.png\" alt=\"\" class=\"wp-image-1560\" srcset=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-59.png 1014w, https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-59-300x15.png 300w, https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-59-768x39.png 768w\" sizes=\"auto, (max-width: 1014px) 100vw, 1014px\" \/><\/figure>\n\n\n\n<p><\/p>\n\n\n\n<p>Both options return a similar Observable. If a Selector of a slice of your State is used repeatedly, you can make it a <a href=\"https:\/\/www.ngxs.io\/concepts\/select#memoized-selectors\" target=\"_blank\" rel=\"noopener\" title=\"\">memoized selector<\/a> by using the <code>@Selector<\/code> decorator in your State class. This example creates a new selector that returns just the currency property of our State:<\/p>\n\n\n<div class=\"wp-block-image\">\n<figure class=\"aligncenter size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"723\" height=\"153\" src=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-60.png\" alt=\"\" class=\"wp-image-1561\" srcset=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-60.png 723w, https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-60-300x63.png 300w\" sizes=\"auto, (max-width: 723px) 100vw, 723px\" \/><\/figure>\n<\/div>\n\n\n<p><\/p>\n\n\n\n<p>Such a Selector can be used with @Select decorator in your components\/services as follows:<\/p>\n\n\n<div class=\"wp-block-image\">\n<figure class=\"aligncenter size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"532\" height=\"90\" src=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-61.png\" alt=\"\" class=\"wp-image-1562\" srcset=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-61.png 532w, https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-61-300x51.png 300w\" sizes=\"auto, (max-width: 532px) 100vw, 532px\" \/><\/figure>\n<\/div>\n\n\n<p><\/p>\n\n\n\n<p>You can see that <a href=\"https:\/\/stackblitz.com\/edit\/at-ngxs-demo?file=src%2Fprice-display%2Fprice-display.component.ts,src%2Fprice-display%2Fprice-display.component.html,src%2Fcurrency.state.ts\" target=\"_blank\" rel=\"noopener\" title=\"\">code in action on Stackblitz<\/a>.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>We know how to create a State and dispatch actions to update its value. Now let&#8217;s see how to receive updates when the State gets updated. Most state management libraries provide what is known as Selectors. A Selector query function runs against our State and returns an Observable. For instance, with NgXs, a Selector can [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[4,38,37],"tags":[],"class_list":["post-1558","post","type-post","status-publish","format-standard","hentry","category-angular","category-ngxs","category-state-management"],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/posts\/1558","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/comments?post=1558"}],"version-history":[{"count":2,"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/posts\/1558\/revisions"}],"predecessor-version":[{"id":1564,"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/posts\/1558\/revisions\/1564"}],"wp:attachment":[{"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/media?parent=1558"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/categories?post=1558"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/tags?post=1558"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}