{"id":3250,"date":"2025-11-12T15:46:53","date_gmt":"2025-11-12T08:46:53","guid":{"rendered":"https:\/\/portal-atlasx.cdg.co.th\/home\/?post_type=docs&#038;p=3250"},"modified":"2025-11-12T15:52:34","modified_gmt":"2025-11-12T08:52:34","slug":"scaffolding","status":"publish","type":"docs","link":"https:\/\/portal-atlasx.cdg.co.th\/home\/docs\/atlasx-web-application\/developing\/scaffolding\/","title":{"rendered":"Scaffolding"},"content":{"rendered":"\n<h1 class=\"wp-block-heading\" id=\"scaffolding\">Scaffolding<\/h1>\n\n\n\n<p>\u0e2b\u0e25\u0e31\u0e07\u0e08\u0e32\u0e01\u0e17\u0e35\u0e48\u0e2a\u0e23\u0e49\u0e32\u0e07 template \u0e02\u0e36\u0e49\u0e19\u0e21\u0e32\u0e41\u0e25\u0e49\u0e27 \u0e43\u0e19\u0e01\u0e32\u0e23\u0e1e\u0e31\u0e12\u0e19\u0e32\u0e2a\u0e48\u0e27\u0e19\u0e17\u0e35\u0e48\u0e40\u0e1b\u0e47\u0e19 Web Application (Angular) \u0e19\u0e31\u0e49\u0e19\u0e08\u0e30\u0e2d\u0e22\u0e39\u0e48\u0e43\u0e19&nbsp;<code>ClientApp<\/code><\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"project-structure\">Project Structure<\/h2>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro\" data-code-block-pro-font-family=\"Code-Pro-Fira-Code\" style=\"font-size:.875rem;font-family:Code-Pro-Fira-Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span role=\"button\" tabindex=\"0\" style=\"color:#000000;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><pre class=\"code-block-pro-copy-button-pre\" aria-hidden=\"true\"><textarea class=\"code-block-pro-copy-button-textarea\" tabindex=\"-1\" aria-hidden=\"true\" readonly>ClientApp\/\n\u2514\u2500\u2500src\/\n    \u251c\u2500\u2500 app\/\n    \u251c\u2500\u2500 assets\/\n    \u251c\u2500\u2500 environments\/\n    \u251c\u2500\u2500 favicon.ico\n    \u251c\u2500\u2500 index.html\n    \u251c\u2500\u2500 main.ts\n    \u251c\u2500\u2500 polyfills.ts\n    \u251c\u2500\u2500 styles.css\n    \u251c\u2500\u2500 test.ts\n    \u2514\u2500\u2500 web.config<\/textarea><\/pre><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M4.5 12.75l6 6 9-13.5\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M16.5 8.25V6a2.25 2.25 0 00-2.25-2.25H6A2.25 2.25 0 003.75 6v8.25A2.25 2.25 0 006 16.5h2.25m8.25-8.25H18a2.25 2.25 0 012.25 2.25V18A2.25 2.25 0 0118 20.25h-7.5A2.25 2.25 0 018.25 18v-1.5m8.25-8.25h-6a2.25 2.25 0 00-2.25 2.25v6\"><\/path><\/svg><\/span><pre class=\"shiki light-plus\" style=\"background-color: #FFFFFF\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #001080\">ClientApp<\/span><span style=\"color: #000000\">\/<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">\u2514\u2500\u2500<\/span><span style=\"color: #001080\">src<\/span><span style=\"color: #000000\">\/<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">app<\/span><span style=\"color: #000000\">\/<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">assets<\/span><span style=\"color: #000000\">\/<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">environments<\/span><span style=\"color: #000000\">\/<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">favicon<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">ico<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">index<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">html<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">main<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">ts<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">polyfills<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">ts<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">styles<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">css<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">test<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">ts<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u2514\u2500\u2500 <\/span><span style=\"color: #001080\">web<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">config<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n<p>\u0e43\u0e19\u0e44\u0e14\u0e40\u0e23\u0e01\u0e17\u0e2d\u0e23\u0e35\u0e48&nbsp;<code>src\/<\/code>&nbsp;\u0e08\u0e30\u0e1b\u0e23\u0e30\u0e01\u0e2d\u0e1a\u0e44\u0e1b\u0e14\u0e49\u0e27\u0e22\u0e44\u0e1f\u0e25\u0e4c\u0e2b\u0e25\u0e32\u0e22 \u0e46 \u0e44\u0e1f\u0e25\u0e4c \u0e40\u0e0a\u0e48\u0e19&nbsp;<code>index.html<\/code>&nbsp;\u0e44\u0e1f\u0e25\u0e4c\u0e04\u0e2d\u0e19\u0e1f\u0e34\u0e01\u0e15\u0e48\u0e32\u0e07 \u0e46 \u0e42\u0e1f\u0e25\u0e40\u0e14\u0e2d\u0e23\u0e4c&nbsp;<code>assets\/<\/code>&nbsp;\u0e2a\u0e33\u0e2b\u0e23\u0e31\u0e1a\u0e40\u0e01\u0e47\u0e1a\u0e44\u0e1f\u0e25\u0e4c\u0e41\u0e25\u0e30\u0e42\u0e04\u0e49\u0e14\u0e02\u0e2d\u0e07\u0e41\u0e2d\u0e1e\u0e17\u0e31\u0e49\u0e07\u0e2b\u0e21\u0e14\u0e08\u0e30\u0e2d\u0e22\u0e39\u0e48\u0e43\u0e19&nbsp;<code>app\/<\/code><\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro\" data-code-block-pro-font-family=\"Code-Pro-Fira-Code\" style=\"font-size:.875rem;font-family:Code-Pro-Fira-Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span role=\"button\" tabindex=\"0\" style=\"color:#000000;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><pre class=\"code-block-pro-copy-button-pre\" aria-hidden=\"true\"><textarea class=\"code-block-pro-copy-button-textarea\" tabindex=\"-1\" aria-hidden=\"true\" readonly>src\/\n  \u2514\u2500\u2500 app\/\n    \u251c\u2500\u2500 core\/\n    \u251c\u2500\u2500 gis\/\n    \u251c\u2500\u2500 home\/\n    \u251c\u2500\u2500 app-routing.module.ts\n    \u251c\u2500\u2500 app.component.html\n    \u251c\u2500\u2500 app.component.spec.ts\n    \u251c\u2500\u2500 app.component.ts\n    \u2514\u2500\u2500 app.module.ts<\/textarea><\/pre><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M4.5 12.75l6 6 9-13.5\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M16.5 8.25V6a2.25 2.25 0 00-2.25-2.25H6A2.25 2.25 0 003.75 6v8.25A2.25 2.25 0 006 16.5h2.25m8.25-8.25H18a2.25 2.25 0 012.25 2.25V18A2.25 2.25 0 0118 20.25h-7.5A2.25 2.25 0 018.25 18v-1.5m8.25-8.25h-6a2.25 2.25 0 00-2.25 2.25v6\"><\/path><\/svg><\/span><pre class=\"shiki light-plus\" style=\"background-color: #FFFFFF\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #001080\">src<\/span><span style=\"color: #000000\">\/<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">  \u2514\u2500\u2500 <\/span><span style=\"color: #001080\">app<\/span><span style=\"color: #000000\">\/<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">core<\/span><span style=\"color: #000000\">\/<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">gis<\/span><span style=\"color: #000000\">\/<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">home<\/span><span style=\"color: #000000\">\/<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">app<\/span><span style=\"color: #000000\">-<\/span><span style=\"color: #001080\">routing<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">module<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">ts<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">app<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">component<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">html<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">app<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">component<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">spec<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">ts<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u251c\u2500\u2500 <\/span><span style=\"color: #001080\">app<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">component<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">ts<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    \u2514\u2500\u2500 <\/span><span style=\"color: #001080\">app<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">module<\/span><span style=\"color: #000000\">.<\/span><span style=\"color: #001080\">ts<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n<p>\u0e43\u0e19\u0e44\u0e14\u0e40\u0e23\u0e01\u0e17\u0e2d\u0e23\u0e35\u0e48&nbsp;<code>src\/app\/<\/code>&nbsp;\u0e1b\u0e23\u0e30\u0e01\u0e2d\u0e1a\u0e14\u0e49\u0e27\u0e22 component \u0e41\u0e25\u0e30 module \u0e02\u0e2d\u0e07\u0e41\u0e2d\u0e1e \u0e15\u0e25\u0e2d\u0e14\u0e08\u0e19\u0e44\u0e14\u0e40\u0e23\u0e47\u0e01\u0e17\u0e2d\u0e23\u0e35\u0e40\u0e1e\u0e34\u0e48\u0e21\u0e40\u0e15\u0e34\u0e21\u0e17\u0e35\u0e48\u0e21\u0e35\u0e04\u0e38\u0e13\u0e2a\u0e21\u0e1a\u0e31\u0e15\u0e34\u0e02\u0e2d\u0e07\u0e41\u0e2d\u0e1e \u0e40\u0e0a\u0e48\u0e19 pages, components, services, \u0e2f\u0e25\u0e2f<\/p>\n\n\n\n<p>\u0e0b\u0e36\u0e48\u0e07\u0e40\u0e23\u0e32\u0e44\u0e14\u0e49\u0e17\u0e33\u0e01\u0e32\u0e23\u0e41\u0e22\u0e01\u0e40\u0e1b\u0e47\u0e19 module \u0e40\u0e2d\u0e32\u0e44\u0e27\u0e49\u0e41\u0e25\u0e30\u0e40\u0e23\u0e35\u0e22\u0e01\u0e43\u0e0a\u0e49\u0e07\u0e32\u0e19\u0e41\u0e1a\u0e1a Lazy-loading modules \u0e2a\u0e33\u0e2b\u0e23\u0e31\u0e1a\u0e01\u0e32\u0e23\u0e1e\u0e31\u0e12\u0e19\u0e32\u0e2b\u0e25\u0e32\u0e22 \u0e46 module \u0e43\u0e19\u0e41\u0e2d\u0e1e\u0e40\u0e14\u0e35\u0e22\u0e27\u0e0b\u0e36\u0e48\u0e07 module \u0e17\u0e35\u0e48\u0e15\u0e34\u0e14\u0e21\u0e32\u0e08\u0e30\u0e21\u0e35&nbsp;<code>gis<\/code>&nbsp;\u0e41\u0e25\u0e30&nbsp;<code>home<\/code>&nbsp;\u0e2a\u0e32\u0e21\u0e32\u0e23\u0e16\u0e14\u0e39\u0e23\u0e32\u0e22\u0e25\u0e30\u0e40\u0e2d\u0e35\u0e22\u0e14\u0e01\u0e32\u0e23\u0e40\u0e23\u0e35\u0e22\u0e01\u0e43\u0e0a\u0e49\u0e07\u0e32\u0e19\u0e44\u0e14\u0e49\u0e17\u0e35\u0e48&nbsp;<a href=\"https:\/\/angular.io\/guide\/lazy-loading-ngmodules\" target=\"_blank\" rel=\"noreferrer noopener\">Angular Lazy-loading feature modules<\/a><\/p>\n","protected":false},"featured_media":0,"parent":3244,"menu_order":2,"comment_status":"closed","ping_status":"closed","template":"","meta":{"nav_title":"","positive":"","negative":"","footnotes":""},"docs_category":[],"class_list":["post-3250","docs","type-docs","status-publish","hentry"],"_links":{"self":[{"href":"https:\/\/portal-atlasx.cdg.co.th\/home\/wp-json\/wp\/v2\/docs\/3250","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/portal-atlasx.cdg.co.th\/home\/wp-json\/wp\/v2\/docs"}],"about":[{"href":"https:\/\/portal-atlasx.cdg.co.th\/home\/wp-json\/wp\/v2\/types\/docs"}],"replies":[{"embeddable":true,"href":"https:\/\/portal-atlasx.cdg.co.th\/home\/wp-json\/wp\/v2\/comments?post=3250"}],"version-history":[{"count":1,"href":"https:\/\/portal-atlasx.cdg.co.th\/home\/wp-json\/wp\/v2\/docs\/3250\/revisions"}],"predecessor-version":[{"id":3251,"href":"https:\/\/portal-atlasx.cdg.co.th\/home\/wp-json\/wp\/v2\/docs\/3250\/revisions\/3251"}],"up":[{"embeddable":true,"href":"https:\/\/portal-atlasx.cdg.co.th\/home\/wp-json\/wp\/v2\/docs\/3244"}],"wp:attachment":[{"href":"https:\/\/portal-atlasx.cdg.co.th\/home\/wp-json\/wp\/v2\/media?parent=3250"}],"wp:term":[{"taxonomy":"docs_category","embeddable":true,"href":"https:\/\/portal-atlasx.cdg.co.th\/home\/wp-json\/wp\/v2\/docs_category?post=3250"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}