{"id":39420,"date":"2023-03-01T19:18:03","date_gmt":"2023-12-08T10:26:39","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5\/"},"modified":"2024-04-29T16:55:06","modified_gmt":"2024-04-29T08:55:06","slug":"%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5\/","title":{"rendered":"\u8d81\u7740\u5b66\u4e60Angular\u5b98\u65b9\u6559\u7a0b\u7684\u540c\u65f6\uff0c\u4e5f\u5b66\u4e60\u70ed\u52a0\u8f7d\u548cMVVM\u7b49\u77e5\u8bc6"},"content":{"rendered":"<h1>\u9996\u5148<\/h1>\n<p>\u5728\u524d\u4e00\u7bc7\u6587\u7ae0\u4e2d\uff0c\u6211\u5efa\u7acb\u4e86\u4e00\u4e2a\u57fa\u4e8eDocker\u7684Angular\u73af\u5883\u3002<br \/>\n\u6211\u5c06\u5e94\u7528\u7a0b\u5e8f\u547d\u540d\u4e3asample-angular-on-docker\u3002<\/p>\n<p>\u8fd9\u6b21\u6211\u4eec\u5c06\u8fdb\u884cAngular\u5b98\u65b9\u6559\u7a0b\u4e2d\u7684\u300a\u6559\u7a0b\uff1a\u82f1\u96c4\u4e4b\u65c5\u300b\u3002<br \/>\n\u672c\u6559\u7a0b\u5c06\u6309\u7167\u4ee5\u4e0b\u7ae0\u8282\u8fdb\u884c\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30a4\u30f3\u30c8\u30ed\u30c0\u30af\u30b7\u30e7\u30f3<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u4f5c\u6210<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\uff11\uff0e\u30d2\u30fc\u30ed\u30fc\u30a8\u30c7\u30a3\u30bf\u30fc<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\uff12\uff0e\u30ea\u30b9\u30c8\u306e\u8868\u793a<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\uff13\uff0e\u30d5\u30a3\u30fc\u30c1\u30e3\u30fc\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u4f5c\u6210<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\uff14\uff0e\u30b5\u30fc\u30d3\u30b9\u306e\u8ffd\u52a0<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\uff15\uff0e\u30ca\u30d3\u30b2\u30fc\u30b7\u30e7\u30f3\u306e\u8ffd\u52a0<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\uff16\uff0e\u30b5\u30fc\u30d0\u30fc\u304b\u3089\u30c7\u30fc\u30bf\u306e\u53d6\u5f97<\/ul>\n<p>\u57fa\u672c\u4e0a\uff0c\u6211\u4f1a\u6309\u7167\u6559\u7a0b\u8fdb\u884c\u64cd\u4f5c\uff0c\u4e0d\u4f1a\u5199\u51fa\u91cd\u590d\u7684\u6587\u7ae0\u3002<br \/>\n\u6211\u4f1a\u5c06\u6bcf\u7ae0\u5361\u58f3\u7684\u5730\u65b9\u548c\u9700\u8981\u7262\u8bb0\u7684\u8981\u70b9\u7559\u4f5c\u6587\u7ae0\u3002<\/p>\n<h1>\u5404\u79cd\u79ef\u5206<\/h1>\n<p>\u6309\u7167\u672c\u6587\u7684\u6807\u9898\u6240\u8ff0\uff0c\u5728\u505a\u6559\u7a0b\u7684\u540c\u65f6\uff0c\u6211\u4eec\u8fd8\u53ef\u4ee5\u5b66\u4e60\u5230\u5f88\u591a\u5176\u4ed6\u7684\u77e5\u8bc6\u3002\u4ee5\u4e0b\u662f\u4e3b\u8981\u7684\u8981\u70b9\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">[POINT] \u30db\u30c3\u30c8\u30ea\u30ed\u30fc\u30c9<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">[POINT] \u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u69cb\u6210<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">[POINT] \u300cspec\u300d\u3063\u3066\u4f55\uff1f<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">[POINT] component \u3068 service \u306e\u9055\u3044<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">[POINT] \u305d\u306e\u4ed6<\/ul>\n<h2>[POINT] \u70ed\u91cd\u8f7d<\/h2>\n<p>\u5f53\u6587\u4ef6\u66f4\u65b0\u65f6\uff0c\u5982\u679c\u80fd\u591f\u8fdb\u884c\u70ed\u91cd\u8f7d\uff0c\u6211\u4f1a\u611f\u5230\u975e\u5e38\u9ad8\u5174\u3002\u7ecf\u8fc7\u8c03\u67e5\uff0c\u53d1\u73b0\u53ea\u9700\u8981\u5728\u542f\u52a8\u9009\u9879\u4e2d\u8bbe\u7f6e &#8211;poll \u53c2\u6570\u5373\u53ef\u3002<br \/>\n\u56e0\u6b64\uff0c\u5728\u542f\u52a8\u65f6\uff0c\u8bf7\u4f7f\u7528\u4ee5\u4e0b\u8bbe\u7f6e\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u3053\u3063\u3061\u3058\u3083\u306a\u304f\u3066<\/span>\r\nroot@60ff460a2f75:\/projects\/app# ng serve <span class=\"nt\">--host<\/span> 0.0.0.0\r\n\r\n<span class=\"c\"># \u3053\u3063\u3061\u3092\u4f7f\u3046\u4e8b\u3067\u3001\u30db\u30c3\u30c8\u30ea\u30ed\u30fc\u30c9\u304c\u3067\u304d\u308b<\/span>\r\nroot@60ff460a2f75:\/projects\/app# ng serve <span class=\"nt\">--host<\/span> 0.0.0.0 <span class=\"nt\">--poll<\/span> 1  <span class=\"c\"># \u8d77\u52d5\u30aa\u30d7\u30b7\u30e7\u30f3 --poll \u3092\u6307\u5b9a<\/span>\r\n<\/code><\/pre>\n<h2>[POINT] \u76ee\u5f55\u7ed3\u6784<\/h2>\n<h3>\u9879\u76ee\u521b\u5efa\u540e\u7684\u76ee\u5f55\u7ed3\u6784<\/h3>\n<p>\u521a\u521b\u5efa\u9879\u76ee\u7684\u76ee\u5f55\u7ed3\u6784\u5982\u4e0b\u3002<\/p>\n<details>sh<br \/>\n.<br \/>\n\u251c\u2500\u2500 README.md<br \/>\n\u251c\u2500\u2500 angular.json<br \/>\n\u251c\u2500\u2500 karma.conf.js<br \/>\n\u251c\u2500\u2500 package-lock.json<br \/>\n\u251c\u2500\u2500 package.json<br \/>\n\u251c\u2500\u2500 tsconfig.app.json<br \/>\n\u251c\u2500\u2500 tsconfig.json<br \/>\n\u251c\u2500\u2500 tsconfig.spec.json<br \/>\n\u251c\u2500\u2500 .browserslistrc<br \/>\n\u251c\u2500\u2500 .editorconfig<br \/>\n\u251c\u2500\u2500 .gitignore<br \/>\n\u251c\u2500\u2500 .vscode<br \/>\n\uff5c \u2514\u2500\u2500 \uff08\u7701\u7565\uff09<br \/>\n\u251c\u2500\u2500 node_modules<br \/>\n\uff5c \u2514\u2500\u2500 \uff08\u7701\u7565\uff09<br \/>\n\u2514\u2500\u2500 src<br \/>\n\u251c\u2500\u2500 app<br \/>\n\u2502\u00a0\u00a0 \u251c\u2500\u2500 app-routing.module.ts<br \/>\n\u2502\u00a0\u00a0 \u251c\u2500\u2500 app.component.css<br \/>\n\u2502\u00a0\u00a0 \u251c\u2500\u2500 app.component.html<br \/>\n\u2502\u00a0\u00a0 \u251c\u2500\u2500 app.component.spec.ts<br \/>\n\u2502\u00a0\u00a0 \u251c\u2500\u2500 app.component.ts<br \/>\n\u2502\u00a0\u00a0 \u2514\u2500\u2500 app.module.ts<br \/>\n\u251c\u2500\u2500 assets<br \/>\n\u251c\u2500\u2500 environments<br \/>\n\u2502\u00a0\u00a0 \u251c\u2500\u2500 environment.prod.ts<br \/>\n\u2502\u00a0\u00a0 \u2514\u2500\u2500 environment.ts<br \/>\n\u251c\u2500\u2500 favicon.ico<br \/>\n\u251c\u2500\u2500 index.html<br \/>\n\u251c\u2500\u2500 main.ts<br \/>\n\u251c\u2500\u2500 polyfills.ts<br \/>\n\u251c\u2500\u2500 styles.css<br \/>\n\u2514\u2500\u2500 test.ts<\/details>\n<h3>\u6559\u7a0b\u5b8c\u6210\u540e\u7684\u76ee\u5f55\u7ed3\u6784<\/h3>\n<p>\u5f53\u4f60\u7ee7\u7eed\u8fdb\u884c\u6559\u7a0b\u65f6\u4f1a\u53d1\u73b0\uff0c\u6bcf\u6b21\u4f7f\u7528Angular CLI\u6267\u884c\u7ec4\u4ef6\u3001\u670d\u52a1\u7b49\u64cd\u4f5c\u65f6\uff0capp\/\u76ee\u5f55\u4e0b\u4f1a\u751f\u6210\u96f6\u6563\u7684\u6587\u4ef6\u3002<\/p>\n<details>\u6307\u5bfc\u5b8c\u6210\u540e\u7684\u76ee\u5f55\u7ed3\u6784sh<br \/>\n.<br \/>\n\u251c\u2500\u2500 README.md<br \/>\n\u251c\u2500\u2500 angular.json<br \/>\n\u251c\u2500\u2500 karma.conf.js<br \/>\n\u251c\u2500\u2500 package-lock.json<br \/>\n\u251c\u2500\u2500 package.json<br \/>\n\u251c\u2500\u2500 tsconfig.app.json<br \/>\n\u251c\u2500\u2500 tsconfig.json<br \/>\n\u251c\u2500\u2500 tsconfig.spec.json<br \/>\n\u251c\u2500\u2500 .browserslistrc<br \/>\n\u251c\u2500\u2500 .editorconfig<br \/>\n\u251c\u2500\u2500 .gitignore<br \/>\n\u251c\u2500\u2500 .vscode<br \/>\n\u2502 \u2514\u2500\u2500 \uff08\u7701\u7565\uff09<br \/>\n\u251c\u2500\u2500 node_modules<br \/>\n\u2502 \u2514\u2500\u2500 \uff08\u7701\u7565\uff09<br \/>\n\u2514\u2500\u2500 src<br \/>\n\u251c\u2500\u2500 app &lt;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;- app\u4e0b\u9762\u771f\u662f\u592a\u591a\u4e86\uff01\u8fd9\u6837\u7ba1\u7406\u4e0d\u4e86\u554a X-(<br \/>\n\u2502 \u251c\u2500\u2500 dashboard<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 dashboard.component.css<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 dashboard.component.html<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 dashboard.component.spec.ts<br \/>\n\u2502 \u2502 \u2514\u2500\u2500 dashboard.component.ts<br \/>\n\u2502 \u251c\u2500\u2500 hero-detail<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 hero-detail.component.css<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 hero-detail.component.html<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 hero-detail.component.spec.ts<br \/>\n\u2502 \u2502 \u2514\u2500\u2500 hero-detail.component.ts<br \/>\n\u2502 \u251c\u2500\u2500 hero-search<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 hero-search.component.css<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 hero-search.component.html<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 hero-search.component.spec.ts<br \/>\n\u2502 \u2502 \u2514\u2500\u2500 hero-search.component.ts<br \/>\n\u2502 \u251c\u2500\u2500 heroes<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 heroes.component.css<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 heroes.component.html<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 heroes.component.spec.ts<br \/>\n\u2502 \u2502 \u2514\u2500\u2500 heroes.component.ts<br \/>\n\u2502 \u251c\u2500\u2500 messages<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 messages.component.css<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 messages.component.html<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 messages.component.spec.ts<br \/>\n\u2502 \u2502 \u2514\u2500\u2500 messages.component.ts<br \/>\n\u2502 \u251c\u2500\u2500 app-routing.module.ts<br \/>\n\u2502 \u251c\u2500\u2500 app.component.css<br \/>\n\u2502 \u251c\u2500\u2500 app.component.html<br \/>\n\u2502 \u251c\u2500\u2500 app.component.spec.ts<br \/>\n\u2502 \u251c\u2500\u2500 app.component.ts<br \/>\n\u2502 \u251c\u2500\u2500 app.module.ts<br \/>\n\u2502 \u251c\u2500\u2500 hero.service.spec.ts<br \/>\n\u2502 \u251c\u2500\u2500 hero.service.ts<br \/>\n\u2502 \u251c\u2500\u2500 hero.ts<br \/>\n\u2502 \u251c\u2500\u2500 in-memory-data.service.spec.ts<br \/>\n\u2502 \u251c\u2500\u2500 in-memory-data.service.ts<br \/>\n\u2502 \u251c\u2500\u2500 message.service.spec.ts<br \/>\n\u2502 \u251c\u2500\u2500 message.service.ts<br \/>\n\u2502 \u2514\u2500\u2500 mock-heroes.ts<br \/>\n\u251c\u2500\u2500 assets<br \/>\n\u251c\u2500\u2500 environments<br \/>\n\u2502 \u251c\u2500\u2500 environment.prod.ts<br \/>\n\u2502 \u2514\u2500\u2500 environment.ts<br \/>\n\u251c\u2500\u2500 favicon.ico<br \/>\n\u251c\u2500\u2500 index.html<br \/>\n\u251c\u2500\u2500 main.ts<br \/>\n\u251c\u2500\u2500 polyfills.ts<br \/>\n\u251c\u2500\u2500 styles.css<br \/>\n\u2514\u2500\u2500 test.ts<\/p>\n<\/details>\n<h3>\u76ee\u5f55\u7ed3\u6784\uff08MVVM\/\u6700\u7ec8\u5f62\u5f0f\uff09<\/h3>\n<p>\u5728\u8fdb\u884c\u6e90\u4ee3\u7801\u7ba1\u7406\u65f6\uff0c\u76ee\u5f55\u7ed3\u6784\u975e\u5e38\u91cd\u8981\uff0c\u4f46\u662f\u5e76\u6ca1\u6709\u660e\u786e\u7684\u6700\u4f73\u5b9e\u8df5\u3002<br \/>\n\u5982\u679c\u4f60\u641c\u7d22\u4e00\u4e0b\uff0c\u4f1a\u53d1\u73b0\u4ee5\u4e0b\u7c7b\u4f3c\u7684\u6587\u7ae0\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">https:\/\/blog.lacolaco.net\/2019\/07\/angular-ngmodule-and-directories\/<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">https:\/\/mya-ake.com\/slides\/regret-angular-web-app<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">https:\/\/mattarishitemota.com\/?p=510<\/ul>\n<p>\u5728\u6559\u7a0b\u4e2d\u867d\u7136\u63d0\u5230\u4e86\u6309&#8221;\u57df\u540d\u5355\u4f4d&#8221;\u6216&#8221;\u7c7b\u578b\u5355\u4f4d&#8221;\u8fdb\u884c\u533a\u5206\uff0c\u4f46\u5728\u6559\u7a0b\u9636\u6bb5\u5e76\u4e0d\u5b58\u5728\u8fd9\u6837\u7684\u5185\u5bb9\u3002<br \/>\n\uff08\u55ef\uff0c\u867d\u7136\u5b58\u5728\uff0c\u4f46\u6211\u4e0d\u60f3\u8003\u8651\uff09<\/p>\n<p>\u57fa\u65bcMVVM\u67b6\u69cb\uff0c\u6211\u5011\u53ef\u4ee5\u5c07Angular\u76f4\u63a5\u7d44\u7e54\u6210\u76ee\u9304\u7d50\u69cb\uff0c\u5982\u6b64\u4e00\u4f86\u5c31\u5b8c\u6210\u4e86\u3002\u6240\u4ee5\u6211\u5011\u6309\u7167MVVM\u7684\u65b9\u5f0f\u7d44\u7e54\u4e86\u76ee\u9304\u3002<\/p>\n<details>MVVM \u518d\u6784\u5efa\u7684\u76ee\u5f55\u7ed3\u6784sh<br \/>\n.<br \/>\n\u251c\u2500\u2500 README.md<br \/>\n\u251c\u2500\u2500 angular.json<br \/>\n\u251c\u2500\u2500 karma.conf.js<br \/>\n\u251c\u2500\u2500 package-lock.json<br \/>\n\u251c\u2500\u2500 package.json<br \/>\n\u251c\u2500\u2500 tsconfig.app.json<br \/>\n\u251c\u2500\u2500 tsconfig.json<br \/>\n\u251c\u2500\u2500 tsconfig.spec.json<br \/>\n\u251c\u2500\u2500 .browserslistrc<br \/>\n\u251c\u2500\u2500 .editorconfig<br \/>\n\u251c\u2500\u2500 .gitignore<br \/>\n\u251c\u2500\u2500 .vscode<br \/>\n\uff5c \u2514\u2500\u2500 \uff08\u7701\u7565\uff09<br \/>\n\u251c\u2500\u2500 node_modules<br \/>\n\uff5c \u2514\u2500\u2500 \uff08\u7701\u7565\uff09<br \/>\n\u2514\u2500\u2500 src<br \/>\n\u251c\u2500\u2500 app &lt;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;- \u53d8\u5f97\u66f4\u52a0\u6e05\u6670\u660e\u4e86\u4e86 \ud83d\ude42<br \/>\n\u2502\u00a0\u00a0 \u251c\u2500\u2500 app-routing.module.ts<br \/>\n\u2502\u00a0\u00a0 \u251c\u2500\u2500 app.module.ts<br \/>\n\u2502 \u251c\u2500\u2500 view<br \/>\n\u2502 \u2502\u00a0\u00a0 \u251c\u2500\u2500 app.component.css<br \/>\n\u2502 \u2502\u00a0\u00a0 \u251c\u2500\u2500 app.component.html<br \/>\n\u2502 \u2502\u00a0\u00a0 \u251c\u2500\u2500 app.component.spec.ts<br \/>\n\u2502 \u2502\u00a0\u00a0 \u251c\u2500\u2500 app.component.ts<br \/>\n\u2502 \u2502\u00a0\u00a0 \u251c\u2500\u2500 dashboard<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u251c\u2500\u2500 dashboard.component.css<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u251c\u2500\u2500 dashboard.component.html<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u251c\u2500\u2500 dashboard.component.spec.ts<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u2514\u2500\u2500 dashboard.component.ts<br \/>\n\u2502 \u2502\u00a0\u00a0 \u251c\u2500\u2500 hero-detail<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u251c\u2500\u2500 hero-detail.component.css<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u251c\u2500\u2500 hero-detail.component.html<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u251c\u2500\u2500 hero-detail.component.spec.ts<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u2514\u2500\u2500 hero-detail.component.ts<br \/>\n\u2502 \u2502\u00a0\u00a0 \u251c\u2500\u2500 hero-search<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u251c\u2500\u2500 hero-search.component.css<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u251c\u2500\u2500 hero-search.component.html<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u251c\u2500\u2500 hero-search.component.spec.ts<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u2514\u2500\u2500 hero-search.component.ts<br \/>\n\u2502 \u2502\u00a0\u00a0 \u251c\u2500\u2500 heroes<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u251c\u2500\u2500 heroes.component.css<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u251c\u2500\u2500 heroes.component.html<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u251c\u2500\u2500 heroes.component.spec.ts<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2502\u00a0\u00a0 \u2514\u2500\u2500 heroes.component.ts<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2514\u2500\u2500 messages<br \/>\n\u2502 \u2502\u00a0\u00a0 \u251c\u2500\u2500 messages.component.css<br \/>\n\u2502 \u2502\u00a0\u00a0 \u251c\u2500\u2500 messages.component.html<br \/>\n\u2502 \u2502\u00a0\u00a0 \u251c\u2500\u2500 messages.component.spec.ts<br \/>\n\u2502 \u2502\u00a0\u00a0 \u2514\u2500\u2500 messages.component.ts<br \/>\n\u2502 \u251c\u2500\u2500 viewmodel<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 hero.service.spec.ts<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 hero.service.ts<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 in-memory-data.service.spec.ts<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 in-memory-data.service.ts<br \/>\n\u2502 \u2502 \u251c\u2500\u2500 message.service.spec.ts<br \/>\n\u2502 \u2502 \u2514\u2500\u2500 message.service.ts<br \/>\n\u2502\u00a0\u00a0 \u2514\u2500\u2500 model<br \/>\n\u2502\u00a0 \u00a0 \u251c\u2500\u2500 hero.ts<br \/>\n\u2502\u00a0 \u00a0 \u2514\u2500\u2500 mock-heroes.ts<br \/>\n\u251c\u2500\u2500 assets<br \/>\n\u251c\u2500\u2500 environments<br \/>\n\u2502\u00a0\u00a0 \u251c\u2500\u2500 environment.prod.ts<br \/>\n\u2502\u00a0\u00a0 \u2514\u2500\u2500 environment.ts<br \/>\n\u251c\u2500\u2500 favicon.ico<br \/>\n\u251c\u2500\u2500 index.html<br \/>\n\u251c\u2500\u2500 main.ts<br \/>\n\u251c\u2500\u2500 polyfills.ts<br \/>\n\u251c\u2500\u2500 styles.css<br \/>\n\u2514\u2500\u2500 test.ts<\/p>\n<\/details>\n<p>\u9806\u5e26\u4e00\u63d0\uff0c\u4f7f\u7528Angular CLI\u521b\u5efa\u7ec4\u4ef6\u548c\u670d\u52a1\u4f1a\u5728app\/\u6587\u4ef6\u5939\u4e0b\u521b\u5efa\uff0c\u4f46\u6267\u884c\u547d\u4ee4\u65f6\u4e5f\u53ef\u4ee5\u521b\u5efa\u6587\u4ef6\u5939\u3002<br \/>\n\u56e0\u6b64\uff0c\u5728\u4f7f\u7528Angular CLI\u8fdb\u884c\u4ee3\u7801\u7ef4\u62a4\u65f6\uff0c\u6211\u8ba4\u4e3a\u6700\u597d\u662f\u5728\u786e\u5b9a\u6587\u4ef6\u5939\u7ed3\u6784\u7684\u57fa\u7840\u4e0a\uff0c\u5bf9\u6267\u884c\u547d\u4ee4\u8fdb\u884c\u9650\u5236\u6765\u8fdb\u884c\u64cd\u4f5c\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u3053\u308c\u3060\u3068 app\/ \u914d\u4e0b\u306b\u4f5c\u3089\u308c\u308b\u306e\u3067\u3001\u7ba1\u7406\u3057\u3065\u3089\u3044<\/span>\r\nroot@c773d67c1823:\/projects\/app# ng generate component heroes\r\n\r\n<span class=\"c\"># \u3053\u308c\u3060\u3068 app\/view\/ \u914d\u4e0b\u306b\u4f5c\u3089\u308c\u308b\u306e\u3067\u3001\u7ba1\u7406\u3057\u3084\u3059\u304f\u306a\u308b<\/span>\r\nroot@c773d67c1823:\/projects\/app# ng generate component view\/heroes\r\n<\/code><\/pre>\n<h2>\u300cspec\u300d\u662f\u4ec0\u4e48\u610f\u601d\uff1f<\/h2>\n<p>\u4f7f\u7528Angular CLI\u751f\u6210\u7ec4\u4ef6\u548c\u670d\u52a1\u65f6\uff0c\u4f1a\u751f\u6210\u4e00\u4e2a\u540d\u4e3axxxx.component.spec.ts\u7684\u6587\u4ef6\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># component \u306e\u751f\u6210<\/span>\r\nroot@c773d67c1823:\/projects\/app# ng generate component heroes\r\nNode.js version v19.0.0 detected.\r\nOdd numbered Node.js versions will not enter LTS status and should not be used <span class=\"k\">for <\/span>production. For more information, please see https:\/\/nodejs.org\/en\/about\/releases\/.\r\n\r\nCREATE src\/app\/heroes\/heroes.component.css <span class=\"o\">(<\/span>0 bytes<span class=\"o\">)<\/span>\r\nCREATE src\/app\/heroes\/heroes.component.html <span class=\"o\">(<\/span>21 bytes<span class=\"o\">)<\/span>\r\nCREATE src\/app\/heroes\/heroes.component.spec.ts <span class=\"o\">(<\/span>599 bytes<span class=\"o\">)<\/span>    &lt;<span class=\"nt\">----------<\/span> \u306a\u306b\u3053\u308c\uff01\uff01\uff01\uff01\uff01\uff01\uff01\uff01\uff01\uff01\uff01\uff01\uff01\uff01\r\nCREATE src\/app\/heroes\/heroes.component.ts <span class=\"o\">(<\/span>275 bytes<span class=\"o\">)<\/span>\r\nUPDATE src\/app\/app.module.ts <span class=\"o\">(<\/span>475 bytes<span class=\"o\">)<\/span>\r\n\r\n<span class=\"c\"># service \u306e\u751f\u6210<\/span>\r\nroot@c773d67c1823:\/projects\/app# ng generate service hero\r\nNode.js version v19.0.0 detected.\r\nOdd numbered Node.js versions will not enter LTS status and should not be used <span class=\"k\">for <\/span>production. For more information, please see https:\/\/nodejs.org\/en\/about\/releases\/.\r\n\r\nCREATE src\/app\/hero.service.spec.ts <span class=\"o\">(<\/span>347 bytes<span class=\"o\">)<\/span>    &lt;<span class=\"nt\">----------<\/span> \u306a\u306b\u3053\u308c\uff01\uff01\uff01\uff01\uff01\uff01\uff01\uff01\uff01\uff01\uff01\uff01\uff01\uff01\r\nCREATE src\/app\/hero.service.ts <span class=\"o\">(<\/span>133 bytes<span class=\"o\">)<\/span>\r\n<\/code><\/pre>\n<p>\u8fd9\u4e2a xxxx.component.spec.ts \u5728\u6559\u7a0b\u4e2d\u4e0d\u4f1a\u88ab\u4f7f\u7528\u3002<br \/>\n\u4e0d\u4f7f\u7528\u5b83\uff0c\u6240\u4ee5\u4e0d\u660e\u767d\u5b83\u751f\u6210\u7684\u76ee\u7684\u662f\u4ec0\u4e48\u3002<\/p>\n<p>\u7ecf\u8fc7\u8c03\u67e5\uff0c\u4f3c\u4e4e\u662f\u9488\u5bf9\u5355\u72ec\u6d4b\u8bd5\u6267\u884c\u7684\u6587\u4ef6\u3002<br \/>\n\u4ee5\u4e0b\u662f\u5b98\u65b9\u7f51\u7ad9\u3002<\/p>\n<ul class=\"post-ul\">https:\/\/angular.jp\/guide\/testing-components-basics<\/ul>\n<h2>\u7ec4\u4ef6\u548c\u670d\u52a1\u7684\u533a\u522b<\/h2>\n<p>\u5148\u524d\u4e00\u76f4\u6df7\u7528\u4e86\u7ec4\u4ef6\u548c\u670d\u52a1\u8fd9\u4e24\u4e2a\u8bcd\uff0c\u4f46\u4e8b\u5b9e\u4e0a\uff0c\u6211\u5e76\u4e0d\u771f\u6b63\u4e86\u89e3\u5b83\u4eec\u7684\u610f\u601d\u3002<\/p>\n<p>\u5f53\u6211\u8fdb\u884c\u8c03\u67e5\u65f6\uff0c\u5728\u5b98\u65b9\u7f51\u7ad9\u4e0a\u53d1\u73b0\u4e86\u4ee5\u4e0b\u5185\u5bb9\u3002<br \/>\n\u8bf7\u770b\u5b98\u65b9\u7f51\u7ad9\u4e0b\u6587\u3002<\/p>\n<ul class=\"post-ul\">https:\/\/angular.jp\/guide\/architecture<\/ul>\n<blockquote><p>\u7ec4\u4ef6\u5b9a\u4e49\u4e86\u89c6\u56fe\u3002<br \/>\n\u89c6\u56fe\u662f\u4ece\u7a0b\u5e8f\u903b\u8f91\u548c\u6570\u636e\u4e2d\u7531Angular\u9009\u62e9\u548c\u66f4\u6539\u7684\u53ef\u53d8\u5c4f\u5e55\u5143\u7d20\u7684\u96c6\u5408\u3002\u6bcf\u4e2a\u5e94\u7528\u7a0b\u5e8f\u81f3\u5c11\u6709\u4e00\u4e2a\u6839\u7ec4\u4ef6\u3002<br \/>\n\u7ec4\u4ef6\u4f7f\u7528\u670d\u52a1\u6765\u63d0\u4f9b\u4e0e\u89c6\u56fe\u65e0\u76f4\u63a5\u5173\u7cfb\u7684\u7279\u5b9a\u529f\u80fd\u3002<br \/>\n\u670d\u52a1\u63d0\u4f9b\u8005\u53ef\u4ee5\u4f5c\u4e3a\u4f9d\u8d56\u9879\u88ab\u6ce8\u5165\u5230\u7ec4\u4ef6\u4e2d\uff0c\u4ee5\u6a21\u5757\u5316\u548c\u6709\u6548\u5730\u5b9e\u73b0\u4ee3\u7801\u7684\u91cd\u7528\u3002<\/p><\/blockquote>\n<p>\u6211\u660e\u767d\u4e86\u3002\u5728\u8fd9\u91cc\uff0cMVVM\u7684\u89c2\u70b9\u5f00\u59cb\u751f\u6548\u3002<br \/>\n\u5c06\u670d\u52a1\u6ce8\u5165\u5230\u7ec4\u4ef6\u4e2d\uff0c\u8fd9\u610f\u5473\u7740\u8fd9\u662f\u6570\u636e\u7ed1\u5b9a\u7684\u673a\u5236\u3002<\/p>\n<p>\u56e0\u6b64\uff0c\u7ec4\u4ef6\u662f\u89c6\u56fe\uff0c\u670d\u52a1\u76f8\u5f53\u4e8e\u89c6\u56fe\u6a21\u578b\u3002<\/p>\n<h3>\u4e86\u89e3\u4e86View\u548cViewModel\uff0c\u90a3Model\u5462\uff1f<\/h3>\n<p>&#8216;\u4f3c\u4e4e ng generate interface {name} \u547d\u4ee4\u53ef\u4ee5\u751f\u6210\u4e0e Model \u76f8\u5f53\u7684\u5185\u5bb9\u3002\u5728\u6559\u7a0b\u4e2d\uff0chero.ts \u53ef\u80fd\u76f8\u5f53\u4e8e\u5b83\uff0c\u4f46\u662f\u7531\u4e8e\u4e0d\u662f\u901a\u8fc7\u547d\u4ee4\u800c\u662f\u76f4\u63a5\u521b\u5efa\u6587\u4ef6\uff0c\u4ece MVVM \u7684\u89d2\u5ea6\u6765\u770b\u53ef\u80fd\u4e0d\u592a\u660e\u663e\u3002&#8217;<\/p>\n<p>\u5982\u679c\u5c1d\u8bd5\u6267\u884c\u4e0a\u8ff0\u547d\u4ee4\uff0c\u4f1a\u751f\u6210\u4ee5\u4e0b\u6587\u4ef6\uff08\u4e0ehero.ts\u5177\u6709\u76f8\u540c\u7684\u7ed3\u6784\uff0c\u6240\u4ee5\u6211\u8ba4\u4e3a\u8fd9\u5c31\u662f\u4e00\u4e2a\u6a21\u578b\uff09\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># interface \u306e\u751f\u6210<\/span>\r\nroot@c773d67c1823:\/projects\/app# ng generate interface model\/dummy\r\nNode.js version v19.0.0 detected.\r\nOdd numbered Node.js versions will not enter LTS status and should not be used <span class=\"k\">for <\/span>production. For more information, please see https:\/\/nodejs.org\/en\/about\/releases\/.\r\nCREATE src\/app\/model\/dummy.ts <span class=\"o\">(<\/span>27 bytes<span class=\"o\">)<\/span>\r\n\r\n<span class=\"c\"># \u30d5\u30a1\u30a4\u30eb\u306e\u78ba\u8a8d<\/span>\r\nroot@c773d67c1823:\/projects\/app# <span class=\"nb\">cat <\/span>src\/app\/model\/dummy.ts\r\n<span class=\"nb\">export <\/span>interface Dummy <span class=\"o\">{<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<h2>[POINT] \u5176\u4ed6<\/h2>\n<p>\u5728\u63a8\u8fdb\u6559\u7a0b\u7684\u8fc7\u7a0b\u4e2d\uff0c\u9664\u4e86\u4ec5\u80fd\u8fdb\u884c\u8868\u9762\u4e0a\u7684\u7406\u89e3\u4e4b\u5916\uff0c\u8fd8\u6709\u4e00\u4e9b\u7528\u6cd5\u4e0d\u592a\u80fd\u7406\u89e3\u7684\u3002\u55ef\uff0c\u968f\u7740\u5f00\u53d1\u7684\u8fdb\u884c\uff0c\u6211\u4f1a\u9010\u6e10\u9002\u5e94\u7684\uff0c\u6240\u4ee5\u73b0\u5728\u53ea\u9700\u8981\u628a\u5b83\u4eec\u5f53\u4f5c\u201c\u539f\u6765\u6709\u8fd9\u6837\u7684\u4e1c\u897f\u201d\u5c31\u597d\u4e86\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30c7\u30fc\u30bf\u30d0\u30a4\u30f3\u30c7\u30a3\u30f3\u30b0\u306b\u306f ngModel \u3092\u7528\u3044\u308b<\/ul>\n<\/li>\n<\/ul>\n<p>ngModel \u3092\u4f7f\u7528\u3059\u308b\u306b\u306f\u3001 FormsModule \u306eimport\u304c\u5fc5\u8981<br \/>\nhttps:\/\/angular.jp\/api\/forms\/NgModel<\/p>\n<p>class\u30d0\u30a4\u30f3\u30c7\u30a3\u30f3\u30b0\u306f\u3001\u4ee5\u4e0b\u3092\u53c2\u7167<\/p>\n<p>\u3053\u308c\u306f\u7279\u306b import \u304c\u5fc5\u8981\u306a\u3069\u306f\u66f8\u304b\u308c\u3066\u3044\u306a\u3044<br \/>\nhttps:\/\/angular.jp\/guide\/class-binding<\/p>\n<p>*ngFor \u3068 *ngIf \u3067 html \u3092\u64cd\u4f5c<br \/>\n\u30eb\u30fc\u30c6\u30a3\u30f3\u30b0\u306f .\/app\/app-routing.module.ts \u3067\u884c\u308f\u308c\u3066\u3001 \u3092\u4f7f\u3046<\/p>\n<h1>\u5b8c\u6210\u6559\u7a0b<\/h1>\n<p>\u6211\u660e\u767d\u4e86\u5982\u4f55\u6784\u5efa\uff0c\u4f46\u5173\u952e\u7684\u6982\u5ff5\u548c\u89c4\u7ea6\u5728\u6559\u7a0b\u4e2d\u5e76\u6ca1\u6709\u88ab\u638c\u63e1\u3002\u6240\u4ee5\uff0c\u6211\u5c06\u53c2\u8003\u5b98\u65b9\u7f51\u7ad9\u7684\u4ee5\u4e0b\u5185\u5bb9\uff0c\u7ee7\u7eed\u5b66\u4e60\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Angular\u306e\u6982\u5ff5\u306e\u7d39\u4ecb<\/ul>\n<\/li>\n<\/ul>\n<p>https:\/\/angular.jp\/guide\/architecture<\/p>\n<p>Angular\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u30b9\u30bf\u30a4\u30eb\u30ac\u30a4\u30c9<\/p>\n<p>https:\/\/angular.jp\/guide\/styleguide<\/p>\n<p>\u7528\u8a9e\u96c6<\/p>\n<p>https:\/\/angular.jp\/guide\/glossary<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u9996\u5148 \u5728\u524d\u4e00\u7bc7\u6587\u7ae0\u4e2d\uff0c\u6211\u5efa\u7acb\u4e86\u4e00\u4e2a\u57fa\u4e8eDocker\u7684Angular\u73af\u5883\u3002 \u6211\u5c06\u5e94\u7528\u7a0b\u5e8f\u547d\u540d\u4e3asample-an [&hellip;]<\/p>\n","protected":false},"author":8,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-39420","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u8d81\u7740\u5b66\u4e60Angular\u5b98\u65b9\u6559\u7a0b\u7684\u540c\u65f6\uff0c\u4e5f\u5b66\u4e60\u70ed\u52a0\u8f7d\u548cMVVM\u7b49\u77e5\u8bc6 - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u8d81\u7740\u5b66\u4e60angular\u5b98\u65b9\u6559\u7a0b\u7684\u540c\u65f6\uff0c\u4e5f\u5b66\u4e60\u70ed\u52a0\u8f7d\u548cmvvm\u7b49\u77e5\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u8d81\u7740\u5b66\u4e60Angular\u5b98\u65b9\u6559\u7a0b\u7684\u540c\u65f6\uff0c\u4e5f\u5b66\u4e60\u70ed\u52a0\u8f7d\u548cMVVM\u7b49\u77e5\u8bc6\" \/>\n<meta property=\"og:description\" content=\"\u9996\u5148 \u5728\u524d\u4e00\u7bc7\u6587\u7ae0\u4e2d\uff0c\u6211\u5efa\u7acb\u4e86\u4e00\u4e2a\u57fa\u4e8eDocker\u7684Angular\u73af\u5883\u3002 \u6211\u5c06\u5e94\u7528\u7a0b\u5e8f\u547d\u540d\u4e3asample-an [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u8d81\u7740\u5b66\u4e60angular\u5b98\u65b9\u6559\u7a0b\u7684\u540c\u65f6\uff0c\u4e5f\u5b66\u4e60\u70ed\u52a0\u8f7d\u548cmvvm\u7b49\u77e5\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-12-08T10:26:39+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-29T08:55:06+00:00\" \/>\n<meta name=\"author\" content=\"\u96c5, \u609f\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u96c5, \u609f\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"4 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5\/\",\"name\":\"\u8d81\u7740\u5b66\u4e60Angular\u5b98\u65b9\u6559\u7a0b\u7684\u540c\u65f6\uff0c\u4e5f\u5b66\u4e60\u70ed\u52a0\u8f7d\u548cMVVM\u7b49\u77e5\u8bc6 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-12-08T10:26:39+00:00\",\"dateModified\":\"2024-04-29T08:55:06+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/f044a4b7fa4ee2701702942002419ca6\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u8d81\u7740\u5b66\u4e60Angular\u5b98\u65b9\u6559\u7a0b\u7684\u540c\u65f6\uff0c\u4e5f\u5b66\u4e60\u70ed\u52a0\u8f7d\u548cMVVM\u7b49\u77e5\u8bc6\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/f044a4b7fa4ee2701702942002419ca6\",\"name\":\"\u96c5, \u609f\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/e71a913e914f1aad1efc391f92084294bac54bc782acd289638580134cf667a6?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/e71a913e914f1aad1efc391f92084294bac54bc782acd289638580134cf667a6?s=96&d=mm&r=g\",\"caption\":\"\u96c5, \u609f\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/yawu\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u8d81\u7740\u5b66\u4e60Angular\u5b98\u65b9\u6559\u7a0b\u7684\u540c\u65f6\uff0c\u4e5f\u5b66\u4e60\u70ed\u52a0\u8f7d\u548cMVVM\u7b49\u77e5\u8bc6 - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u8d81\u7740\u5b66\u4e60angular\u5b98\u65b9\u6559\u7a0b\u7684\u540c\u65f6\uff0c\u4e5f\u5b66\u4e60\u70ed\u52a0\u8f7d\u548cmvvm\u7b49\u77e5\/","og_locale":"zh_CN","og_type":"article","og_title":"\u8d81\u7740\u5b66\u4e60Angular\u5b98\u65b9\u6559\u7a0b\u7684\u540c\u65f6\uff0c\u4e5f\u5b66\u4e60\u70ed\u52a0\u8f7d\u548cMVVM\u7b49\u77e5\u8bc6","og_description":"\u9996\u5148 \u5728\u524d\u4e00\u7bc7\u6587\u7ae0\u4e2d\uff0c\u6211\u5efa\u7acb\u4e86\u4e00\u4e2a\u57fa\u4e8eDocker\u7684Angular\u73af\u5883\u3002 \u6211\u5c06\u5e94\u7528\u7a0b\u5e8f\u547d\u540d\u4e3asample-an [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u8d81\u7740\u5b66\u4e60angular\u5b98\u65b9\u6559\u7a0b\u7684\u540c\u65f6\uff0c\u4e5f\u5b66\u4e60\u70ed\u52a0\u8f7d\u548cmvvm\u7b49\u77e5\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-12-08T10:26:39+00:00","article_modified_time":"2024-04-29T08:55:06+00:00","author":"\u96c5, \u609f","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u96c5, \u609f","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"4 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5\/","name":"\u8d81\u7740\u5b66\u4e60Angular\u5b98\u65b9\u6559\u7a0b\u7684\u540c\u65f6\uff0c\u4e5f\u5b66\u4e60\u70ed\u52a0\u8f7d\u548cMVVM\u7b49\u77e5\u8bc6 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-12-08T10:26:39+00:00","dateModified":"2024-04-29T08:55:06+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/f044a4b7fa4ee2701702942002419ca6"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u8d81\u7740\u5b66\u4e60Angular\u5b98\u65b9\u6559\u7a0b\u7684\u540c\u65f6\uff0c\u4e5f\u5b66\u4e60\u70ed\u52a0\u8f7d\u548cMVVM\u7b49\u77e5\u8bc6"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/f044a4b7fa4ee2701702942002419ca6","name":"\u96c5, \u609f","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/e71a913e914f1aad1efc391f92084294bac54bc782acd289638580134cf667a6?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/e71a913e914f1aad1efc391f92084294bac54bc782acd289638580134cf667a6?s=96&d=mm&r=g","caption":"\u96c5, \u609f"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/yawu\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e8%b6%81%e7%9d%80%e5%ad%a6%e4%b9%a0angular%e5%ae%98%e6%96%b9%e6%95%99%e7%a8%8b%e7%9a%84%e5%90%8c%e6%97%b6%ef%bc%8c%e4%b9%9f%e5%ad%a6%e4%b9%a0%e7%83%ad%e5%8a%a0%e8%bd%bd%e5%92%8cmvvm%e7%ad%89%e7%9f%a5\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39420","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/8"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=39420"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39420\/revisions"}],"predecessor-version":[{"id":86484,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39420\/revisions\/86484"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=39420"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=39420"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=39420"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}