{"id":1464,"date":"2023-09-18T05:00:00","date_gmt":"2023-09-18T12:00:00","guid":{"rendered":"https:\/\/www.angulartraining.com\/daily-newsletter\/?p=1464"},"modified":"2023-09-13T14:47:14","modified_gmt":"2023-09-13T21:47:14","slug":"angular-16-2-ngcomponentoutlet-input-bindings","status":"publish","type":"post","link":"https:\/\/www.angulartraining.com\/daily-newsletter\/angular-16-2-ngcomponentoutlet-input-bindings\/","title":{"rendered":"Angular 16.2: NgComponentOutlet input bindings"},"content":{"rendered":"\n<p>Another feature of Angular 16.2 is using input bindings with component outlets. You might not be familiar with <code><a href=\"https:\/\/angular.io\/api\/common\/NgComponentOutlet\" target=\"_blank\" rel=\"noopener\" title=\"\">ngComponentOutlet<\/a><\/code> in the first place, so let&#8217;s explain what the directive does. <\/p>\n\n\n\n<p>Let&#8217;s consider the following template syntax:<\/p>\n\n\n<div class=\"wp-block-image\">\n<figure class=\"aligncenter size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"729\" height=\"43\" src=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-20.png\" alt=\"\" class=\"wp-image-1465\" srcset=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-20.png 729w, https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-20-300x18.png 300w\" sizes=\"auto, (max-width: 729px) 100vw, 729px\" \/><\/figure>\n<\/div>\n\n\n<p><\/p>\n\n\n\n<p>The above code would load a dynamic component into the <code><a href=\"https:\/\/www.angulartraining.com\/daily-newsletter\/what-is-ng-container\/\" target=\"_blank\" rel=\"noopener\" title=\"\">ng-container<\/a><\/code>. Assigning a new component type to <code>componentTypeExpression<\/code> would display it in that container. Here&#8217;s a basic example that shows a <code>HelloComponent<\/code> in the component outlet:<\/p>\n\n\n<div class=\"wp-block-image\">\n<figure class=\"aligncenter size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"611\" height=\"341\" src=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-21.png\" alt=\"\" class=\"wp-image-1466\" srcset=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-21.png 611w, https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-21-300x167.png 300w\" sizes=\"auto, (max-width: 611px) 100vw, 611px\" \/><\/figure>\n<\/div>\n\n\n<p><\/p>\n\n\n\n<p>This can be helpful if you need to use different types of components and don&#8217;t want to (or can&#8217;t) use the router to make it happen.<\/p>\n\n\n\n<p>The new feature of Angular 16.2 allows us to pass input values to that component. Let&#8217;s assume that <code>HelloComponent<\/code> looks like this:<\/p>\n\n\n<div class=\"wp-block-image\">\n<figure class=\"aligncenter size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"360\" height=\"182\" src=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-22.png\" alt=\"\" class=\"wp-image-1467\" srcset=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-22.png 360w, https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-22-300x152.png 300w\" sizes=\"auto, (max-width: 360px) 100vw, 360px\" \/><\/figure>\n<\/div>\n\n\n<p><\/p>\n\n\n\n<p>We can bind a value to the <code>name<\/code> input as follows:<\/p>\n\n\n<div class=\"wp-block-image\">\n<figure class=\"aligncenter size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"802\" height=\"269\" src=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-23.png\" alt=\"\" class=\"wp-image-1468\" srcset=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-23.png 802w, https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-23-300x101.png 300w, https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/09\/image-23-768x258.png 768w\" sizes=\"auto, (max-width: 802px) 100vw, 802px\" \/><\/figure>\n<\/div>\n\n\n<p><\/p>\n\n\n\n<p>And that does the trick! You can see an <a href=\"https:\/\/stackblitz.com\/edit\/stackblitz-starters-wk3aqq?description=An%20angular-cli%20project%20based%20on%20@angular\/animations,%20@angular\/common,%20@angular\/compiler,%20@angular\/core,%20@angular\/forms,%20@angular\/platform-browser,%20@angular\/platform-browser-dynamic,%20@angular\/router,%20core-js,%20rxjs,%20tslib%20and%20zone.js&amp;file=src%2Fmain.ts,src%2Fhello%2Fhello.component.ts,src%2Fhello%2Fhello.component.html&amp;title=Angular%20Starter\" target=\"_blank\" rel=\"noopener\" title=\"\">example in action on Stackblitz here<\/a>. <code>inputs<\/code> is an object that can have as many keys as needed. In my example, there is only one: <code>name<\/code>.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Another feature of Angular 16.2 is using input bindings with component outlets. You might not be familiar with ngComponentOutlet in the first place, so let&#8217;s explain what the directive does. Let&#8217;s consider the following template syntax: The above code would load a dynamic component into the ng-container. Assigning a new component type to componentTypeExpression would [&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,8,11],"tags":[],"class_list":["post-1464","post","type-post","status-publish","format-standard","hentry","category-angular","category-components","category-directives"],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/posts\/1464","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=1464"}],"version-history":[{"count":3,"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/posts\/1464\/revisions"}],"predecessor-version":[{"id":1471,"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/posts\/1464\/revisions\/1471"}],"wp:attachment":[{"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/media?parent=1464"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/categories?post=1464"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/tags?post=1464"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}