{"id":39092,"date":"2023-05-02T17:51:57","date_gmt":"2023-08-30T17:33:39","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91\/"},"modified":"2024-04-30T02:17:48","modified_gmt":"2024-04-29T18:17:48","slug":"angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91\/","title":{"rendered":"Angular2 5\u5206\u949f\u5feb\u901f\u5165\u95e8\uff08\u5e26\u6709TypeScript\u89e3\u91ca\uff09\u7684\u7ffb\u8bd1"},"content":{"rendered":"<p>\u6211\u5728Google I\/O 2016\u4e2d\u770b\u5230\u4e86\u5f88\u591a\u4f1a\u8bae\uff0c\u6211\u4e3a\u5373\u5c06\u6765\u4e34\u7684\u670d\u52a1\u5f00\u53d1\u63d0\u9ad8\u6548\u7387\u7684\u6846\u67b6Angular2\u76845\u5206\u949f\u5feb\u901f\u5165\u95e8\u8fdb\u884c\u4e86\u7ffb\u8bd1\u3002\u7531\u4e8e\u6211\u7ffb\u8bd1\u5305\u542b\u4e86\u539f\u6587\u4e2d\u7684\u6240\u6709\u8bf4\u660e\uff0c\u6240\u4ee5\u53ef\u80fd\u9700\u8981\u8d85\u8fc730\u5206\u949f\u7684\u65f6\u95f4\uff0c\u8bf7\u4e0d\u8981\u76f8\u4fe15\u5206\u949f\u7684\u8bf4\u6cd5\u3002<\/p>\n<p>\u8bf7\u8f6c\u5230\u6b64\u5904\u4ee5\u67e5\u770b\u7701\u7565\u4e86\u6240\u6709\u8bf4\u660e\u7684\u5185\u5bb9\uff0c\u5e76\u5728\u90a3\u91cc\u6311\u62185\u5206\u949f\u5185\u7684Hello World\u6210\u529f\u3002<\/p>\n<hr \/>\n<p>\u6211\u4eec\u7684QuickStart\u76ee\u6807\u662f\u6784\u5efa\u548c\u8fd0\u884c\u4e00\u4e2a\u975e\u5e38\u7b80\u5355\u7684TypeScript Angular 2\u5e94\u7528\u7a0b\u5e8f\u3002\u800c\u5728\u672c\u6587\u4e4b\u5916\u7684\u6559\u7a0b\u548c\u6587\u6863\u4e2d\uff0c\u63d0\u5230\u7684\u793a\u4f8b\u662f\u57fa\u4e8e\u5b9e\u9645\u5e94\u7528\u7a0b\u5e8f\u7684\u57fa\u7840\u3002\u4f46\u5728\u672c\u6587\u4e2d\uff0c\u6211\u4eec\u4e5f\u5c06\u5efa\u7acb\u4e3a\u8fd9\u4e9b\u793a\u4f8b\u63d0\u4f9b\u5f00\u53d1\u73af\u5883\u7684\u6b65\u9aa4\u3002<\/p>\n<h2>\u6765\u8bd5\u8bd5\u770b\u5427!<\/h2>\n<p>\u8bf7\u5c1d\u8bd5\u6267\u884c\u4e00\u4e2a\u53ef\u884c\u7684\u793a\u4f8b\u3002\u5c06\u793a\u4f8b\u5e94\u7528\u52a0\u8f7d\u5230Plunker\u4e2d\uff0c\u5e76\u663e\u793a\u793a\u4f8b\u6d88\u606f\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d385b37434c4406c75b5c\/6-0.png\" alt=\"mes\" \/><\/div>\n<h2>\u8ba9\u6211\u4eec\u6765\u6784\u5efa\u4e00\u4e2a\u5e94\u7528\u7a0b\u5e8f\uff01\uff08\u76ee\u5f55\uff09<\/h2>\n<p>* \u524d\u63d0\u6761\u4ef6: \u5b89\u88c5 Node.js\u3002<br \/>\n* \u6b65\u9aa41\uff1a\u521b\u5efa\u5e94\u7528\u9879\u76ee\u6587\u4ef6\u5939\uff0c\u5e76\u5b9a\u4e49\u5305\u4f9d\u8d56\u548c\u7279\u6b8a\u9879\u76ee\u8bbe\u7f6e\u3002<br \/>\n* \u6b65\u9aa42\uff1a\u521b\u5efa\u5e94\u7528\u7684 Angular \u6839\u7ec4\u4ef6\u3002<br \/>\n* \u6b65\u9aa43\uff1a\u6dfb\u52a0 main.ts\uff0c\u5e76\u6307\u5b9a\u6839\u7ec4\u4ef6\u7ed9 Angular\u3002<br \/>\n* \u6b65\u9aa44\uff1a\u6dfb\u52a0\u7528\u4e8e\u6258\u7ba1\u5e94\u7528\u7684 index.html\u3002<br \/>\n* \u6b65\u9aa45\uff1a\u6784\u5efa\u5e76\u8fd0\u884c\u5e94\u7528\u3002<br \/>\n* \u5bf9\u5e94\u7528\u8fdb\u884c\u4e00\u4e9b\u4fee\u6539\u3002<br \/>\n* \u7ed3\u675f<\/p>\n<h2>Node.js\u7684\u524d\u63d0\u662f<\/h2>\n<p>\u5982\u679c\u5c1a\u672a\u5b89\u88c5\uff0c\u8bf7\u5b89\u88c5Node.js\u00ae\u548cnpm\u3002<\/p>\n<blockquote><p>\u8bf7\u5728\u7ec8\u7aef\u6216\u63a7\u5236\u53f0\u7a97\u53e3\u4e2d\u8fd0\u884cnode -v\u548cnpm -v\u547d\u4ee4\u6765\u786e\u8ba4\u60a8\u7684node\u7248\u672c\u4e3av5.x.x\uff0cnpm\u7248\u672c\u4e3a3.x.x\u3002\u8fc7\u65e7\u6216\u8fc7\u65b0\u7684\u7248\u672c\u5c06\u4f1a\u4ea7\u751f\u9519\u8bef\u3002<\/p><\/blockquote>\n<p>\uff08\u5907\u6ce8\uff1a\u7531\u4e8enode\u7684\u6700\u65b0\u7248\u672c\u662f6.x\uff0c\u56e0\u6b64\u5b89\u88c5nvm\u6216\u8fdb\u884c\u5e72\u51c0\u5b89\u88c5\u65e7\u7248\u672c\u53ef\u80fd\u662f\u4e00\u4e2a\u4e0d\u9519\u7684\u9009\u62e9\u3002\uff09<\/p>\n<blockquote><p>\u4e0b\u9762\u662f\u4e0b\u8f7d\u6e90\u4ee3\u7801\u7684\u51e0\u4e2a\u6b65\u9aa4\u3002<\/p>\n<p>\u60a8\u53ef\u4ee5\u8df3\u8fc7\u4e0b\u9762\u7684\u6b65\u9aa4\uff0c\u76f4\u63a5\u4eceGitHub\u4e0a\u4e0b\u8f7dQuickStart\u7684\u6e90\u4ee3\u7801\uff0c\u7136\u540e\u6309\u4ee5\u4e0b\u7b80\u5355\u6b65\u9aa4\u5b8c\u6210\u3002<\/p><\/blockquote>\n<h2>\u6b65\u9aa4\u4e00\uff1a\u521b\u5efa\u548c\u8bbe\u7f6e\u9879\u76ee<\/h2>\n<p>\u5728\u8fd9\u4e2a\u6b65\u9aa4\u4e2d\uff0c\u6211\u4eec\u5c06\u5904\u7406\u4ee5\u4e0b\u4e8b\u9879\u3002<\/p>\n<p>(a) \u521b\u5efa\u9879\u76ee\u6587\u4ef6\u5939\u3002<br \/>\n(b) \u6dfb\u52a0\u5305\u5b9a\u4e49\u548c\u914d\u7f6e\u6587\u4ef6\u3002<br \/>\n(c) \u5b89\u88c5\u5305\u3002<\/p>\n<h3>(a) \u521b\u5efa\u9879\u76ee\u6587\u4ef6\u5939\u3002<\/h3>\n<pre class=\"post-pre\"><code>&gt; mkdir angular2-quickstart\r\n&gt; cd    angular2-quickstart\r\n\r\n<\/code><\/pre>\n<h3>(b) \u6dfb\u52a0\u5305\u5b9a\u4e49\u548c\u914d\u7f6e\u6587\u4ef6\u3002<\/h3>\n<p>\u5c06\u4ee5\u4e0b\u7684\u5305\u5b9a\u4e49\u6587\u4ef6\u548c\u914d\u7f6e\u6587\u4ef6\u6dfb\u52a0\u5230\u9879\u76ee\u6587\u4ef6\u5939\u4e2d\u3002<\/p>\n<p>package.json\u6587\u4ef6\u5217\u51fa\u4e86QuickStart\u5e94\u7528\u6240\u4f9d\u8d56\u7684\u8f6f\u4ef6\u5305\uff0c\u5e76\u5b9a\u4e49\u4e86\u4e00\u4e9b\u6709\u7528\u7684\u811a\u672c\u3002\u6709\u5173\u8be6\u7ec6\u4fe1\u606f\uff0c\u8bf7\u53c2\u9605NPM\u8f6f\u4ef6\u5305\u914d\u7f6e\u3002<\/p>\n<p>tsconfig.json \u662f TypeScript \u7f16\u8bd1\u5668\u7684\u914d\u7f6e\u6587\u4ef6\u3002\u8bf7\u53c2\u9605 TypeScript \u7684\u914d\u7f6e\u4ee5\u83b7\u53d6\u8be6\u7ec6\u4fe1\u606f\u3002<\/p>\n<p>typings.json \u662f TypeScript \u7684\u5b9a\u4e49\u6587\u4ef6\u3002\u66f4\u591a\u8be6\u7ec6\u4fe1\u606f\uff0c\u8bf7\u67e5\u770b TypeScript \u7684\u914d\u7f6e\u3002<\/p>\n<p>systemjs.config.js\u662fSystemJS\u7684\u914d\u7f6e\u6587\u4ef6\u3002\u4e0b\u9762\u5c06\u8fdb\u884c\u8ba8\u8bba\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"p\">{<\/span>\r\n  <span class=\"nl\">\"name\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"angular2-quickstart\"<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nl\">\"version\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"1.0.0\"<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nl\">\"scripts\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"start\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"tsc &amp;&amp; concurrently <\/span><span class=\"se\">\\\"<\/span><span class=\"s2\">npm run tsc:w<\/span><span class=\"se\">\\\"<\/span> <span class=\"se\">\\\"<\/span><span class=\"s2\">npm run lite<\/span><span class=\"se\">\\\"<\/span><span class=\"s2\"> \"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"lite\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"lite-server\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"postinstall\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"typings install\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"tsc\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"tsc\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"tsc:w\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"tsc -w\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"typings\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"typings\"<\/span>\r\n  <span class=\"p\">},<\/span>\r\n  <span class=\"nl\">\"license\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"ISC\"<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nl\">\"dependencies\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"@angular\/common\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/compiler\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/core\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/http\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/platform-browser\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/platform-browser-dynamic\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/router\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/router-deprecated\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/upgrade\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"systemjs\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"0.19.27\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"core-js\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"^2.4.0\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"reflect-metadata\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"^0.1.3\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"rxjs\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"5.0.0-beta.6\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"zone.js\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"^0.6.12\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"angular2-in-memory-web-api\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"0.0.10\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"bootstrap\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"^3.3.6\"<\/span>\r\n  <span class=\"p\">},<\/span>\r\n  <span class=\"nl\">\"devDependencies\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"concurrently\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"^2.0.0\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"lite-server\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"^2.2.0\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"typescript\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"^1.8.10\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"typings\"<\/span><span class=\"p\">:<\/span><span class=\"s2\">\"^1.0.4\"<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"p\">{<\/span>\r\n  <span class=\"nl\">\"compilerOptions\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"target\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"es5\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"module\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"commonjs\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"moduleResolution\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"node\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"sourceMap\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"emitDecoratorMetadata\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"experimentalDecorators\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"removeComments\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">false<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"noImplicitAny\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">false<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"p\">{<\/span>\r\n  <span class=\"nl\">\"globalDependencies\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"core-js\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"registry:dt\/core-js#0.0.0+20160317120654\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"jasmine\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"registry:dt\/jasmine#2.2.0+20160505161446\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"node\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"registry:dt\/node#4.0.0+20160509154515\"<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"cm\">\/**\r\n * System configuration for Angular 2 samples\r\n * Adjust as necessary for your application needs.\r\n *\/<\/span>\r\n<span class=\"p\">(<\/span><span class=\"kd\">function<\/span><span class=\"p\">(<\/span><span class=\"nb\">global<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"c1\">\/\/ map tells the System loader where to look for things<\/span>\r\n  <span class=\"kd\">var<\/span> <span class=\"nx\">map<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">app<\/span><span class=\"dl\">'<\/span><span class=\"p\">:<\/span>                        <span class=\"dl\">'<\/span><span class=\"s1\">app<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"c1\">\/\/ 'dist',<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">@angular<\/span><span class=\"dl\">'<\/span><span class=\"p\">:<\/span>                   <span class=\"dl\">'<\/span><span class=\"s1\">node_modules\/@angular<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">angular2-in-memory-web-api<\/span><span class=\"dl\">'<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">node_modules\/angular2-in-memory-web-api<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">rxjs<\/span><span class=\"dl\">'<\/span><span class=\"p\">:<\/span>                       <span class=\"dl\">'<\/span><span class=\"s1\">node_modules\/rxjs<\/span><span class=\"dl\">'<\/span>\r\n  <span class=\"p\">};<\/span>\r\n  <span class=\"c1\">\/\/ packages tells the System loader how to load when no filename and\/or no extension<\/span>\r\n  <span class=\"kd\">var<\/span> <span class=\"nx\">packages<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">app<\/span><span class=\"dl\">'<\/span><span class=\"p\">:<\/span>                        <span class=\"p\">{<\/span> <span class=\"na\">main<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">main.js<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>  <span class=\"na\">defaultExtension<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">js<\/span><span class=\"dl\">'<\/span> <span class=\"p\">},<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">rxjs<\/span><span class=\"dl\">'<\/span><span class=\"p\">:<\/span>                       <span class=\"p\">{<\/span> <span class=\"na\">defaultExtension<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">js<\/span><span class=\"dl\">'<\/span> <span class=\"p\">},<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">angular2-in-memory-web-api<\/span><span class=\"dl\">'<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span> <span class=\"na\">defaultExtension<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">js<\/span><span class=\"dl\">'<\/span> <span class=\"p\">},<\/span>\r\n  <span class=\"p\">};<\/span>\r\n  <span class=\"kd\">var<\/span> <span class=\"nx\">ngPackageNames<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">common<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">compiler<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">core<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">http<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">platform-browser<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">platform-browser-dynamic<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">router<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">router-deprecated<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">upgrade<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"p\">];<\/span>\r\n  <span class=\"c1\">\/\/ Add package entries for angular packages<\/span>\r\n  <span class=\"nx\">ngPackageNames<\/span><span class=\"p\">.<\/span><span class=\"nx\">forEach<\/span><span class=\"p\">(<\/span><span class=\"kd\">function<\/span><span class=\"p\">(<\/span><span class=\"nx\">pkgName<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">packages<\/span><span class=\"p\">[<\/span><span class=\"dl\">'<\/span><span class=\"s1\">@angular\/<\/span><span class=\"dl\">'<\/span><span class=\"o\">+<\/span><span class=\"nx\">pkgName<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span> <span class=\"na\">main<\/span><span class=\"p\">:<\/span> <span class=\"nx\">pkgName<\/span> <span class=\"o\">+<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">.umd.js<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"na\">defaultExtension<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">js<\/span><span class=\"dl\">'<\/span> <span class=\"p\">};<\/span>\r\n  <span class=\"p\">});<\/span>\r\n  <span class=\"kd\">var<\/span> <span class=\"nx\">config<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"na\">map<\/span><span class=\"p\">:<\/span> <span class=\"nx\">map<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">packages<\/span><span class=\"p\">:<\/span> <span class=\"nx\">packages<\/span>\r\n  <span class=\"p\">}<\/span>\r\n  <span class=\"nx\">System<\/span><span class=\"p\">.<\/span><span class=\"nx\">config<\/span><span class=\"p\">(<\/span><span class=\"nx\">config<\/span><span class=\"p\">);<\/span>\r\n<span class=\"p\">})(<\/span><span class=\"k\">this<\/span><span class=\"p\">);<\/span>\r\n\r\n<\/code><\/pre>\n<h3>(c) \u5b89\u88c5\u8f6f\u4ef6\u5305\u3002<\/h3>\n<p>\u8bf7\u4f7f\u7528npm\u5b89\u88c5\u5728package.json\u4e2d\u5217\u51fa\u7684\u8f6f\u4ef6\u5305\u3002\u8bf7\u5c06\u4ee5\u4e0b\u547d\u4ee4\u8f93\u5165\u5230\u7ec8\u7aef\u7a97\u53e3\uff08\u5728Windows\u4e0a\u662f\u547d\u4ee4\u7a97\u53e3\uff09\u4e2d\u3002<\/p>\n<pre class=\"post-pre\"><code>&gt; npm install\r\n\r\n<\/code><\/pre>\n<blockquote><p>\u5728\u5b89\u88c5\u8fc7\u7a0b\u4e2d\uff0c\u53ef\u80fd\u4f1a\u4ee5\u7ea2\u8272\u6587\u5b57\u663e\u793a\u9700\u8981\u6ce8\u610f\u7684\u9519\u8bef\u3002\u5927\u591a\u6570\u60c5\u51b5\u4e0b\uff0c\u5b89\u88c5\u4f1a\u6b63\u786e\u5904\u7406\u8fd9\u4e9b\u9519\u8bef\u5e76\u6210\u529f\u5b8c\u6210\u3002<\/p>\n<p>npm\u9519\u8bef\u548c\u8b66\u544a<\/p>\n<p>\u5982\u679c\u5728npm install\u5b8c\u6210\u540e\uff0c\u63a7\u5236\u53f0\u4e0a\u6ca1\u6709\u663e\u793a\u4ee5npm ERR!\u5f00\u5934\u7684\u6d88\u606f\uff0c\u5219\u8bf4\u660e\u4e00\u5207\u90fd\u8fdb\u884c\u5f97\u5f88\u987a\u5229\u3002\u53ef\u80fd\u4f1a\u5728\u4e2d\u9014\u663e\u793a\u4e00\u4e9bnpm WARN\u6d88\u606f\uff0c\u4f46\u5373\u4f7f\u8fd9\u6837\uff0c\u4e5f\u6ca1\u6709\u95ee\u9898\u3002<\/p>\n<p>\u901a\u5e38\u5728\u51fa\u73b0gyp ERR!\u540e\u4f1a\u63a5\u7740\u770b\u5230\u4e00\u4e9bnpm WARN\u6d88\u606f\uff0c\u4f46\u8bf7\u5ffd\u7565\u5b83\u4eec\u3002\u5982\u679c\u9700\u8981\u4f7f\u7528node-gyp\u91cd\u65b0\u7f16\u8bd1\u5305\uff0c\u53ef\u80fd\u9700\u8981\u4f7f\u7528\u5b83\u4eec\u3002\u5982\u679c\u91cd\u65b0\u7f16\u8bd1\u5931\u8d25\uff0c\u5305\u5c06\u4f1a\u88ab\u6062\u590d\uff08\u901a\u5e38\u662f\u7f16\u8bd1\u540e\u7684\u7248\u672c\uff09\uff0c\u4e00\u5207\u90fd\u5c06\u6b63\u5e38\u8fd0\u884c\u3002<\/p>\n<p>\u8bf7\u52a1\u5fc5\u786e\u4fdd\u5728npm install\u5b8c\u6210\u540e\u6ca1\u6709\u51fa\u73b0npm ERR!\u6d88\u606f\u3002<\/p>\n<p>\u4f7f\u7528npm\u6dfb\u52a0\u6240\u9700\u7684\u5e93\u548c\u5305<\/p>\n<p>\u5728\u5f00\u53d1Angular\u5e94\u7528\u7a0b\u5e8f\u65f6\uff0c\u5c06\u5b89\u88c5\u6240\u9700\u7684\u5e93\u548c\u5305\u7684\u4efb\u52a1\u4ea4\u7ed9npm\u5305\u7ba1\u7406\u5668\u3002Angular\u56e2\u961f\u5efa\u8bae\u4e3adependencies\u548cdevDependencies\u90e8\u5206\u63d0\u4f9b\u4e00\u4e2a\u8d77\u59cb\u8bbe\u7f6e\u5305\u3002\u6709\u5173\u8be6\u7ec6\u4fe1\u606f\uff0c\u8bf7\u53c2\u9605npm packages\u9875\u9762\u3002<\/p>\n<p>\u6709\u7528\u7684\u811a\u672c<\/p>\n<p>\u6211\u4eec\u5efa\u8bae\u5728package.json\u4e2d\u63d0\u4f9b\u4e00\u4e9b\u811a\u672c\u3002\u5b83\u4eec\u5c06\u5904\u7406\u5f00\u53d1\u4e2d\u7684\u5171\u540c\u4efb\u52a1\u3002<\/p>\n<p>&#8220;`package.json (scripts)<\/p>\n<p>{<br \/>\n&#8220;scripts&#8221;: {<br \/>\n&#8220;start&#8221;: &#8220;tsc &amp;&amp; concurrently \\&#8221;npm run tsc:w\\&#8221; \\&#8221;npm run lite\\&#8221; &#8220;,<br \/>\n&#8220;lite&#8221;: &#8220;lite-server&#8221;,<br \/>\n&#8220;postinstall&#8221;: &#8220;typings install&#8221;,<br \/>\n&#8220;tsc&#8221;: &#8220;tsc&#8221;,<br \/>\n&#8220;tsc:w&#8221;: &#8220;tsc -w&#8221;,<br \/>\n&#8220;typings&#8221;: &#8220;typings&#8221;<br \/>\n}<br \/>\n}<br \/>\n&#8220;`<br \/>\nnpm\u811a\u672c\u901a\u5e38\u901a\u8fc7npm run script name\u65b9\u5f0f\u6267\u884c\u3002\uff08\u4f8b\u5982start\uff09\u3002\u6709\u4e9b\u547d\u4ee4\u4e0d\u9700\u8981run\u5173\u952e\u5b57\u3002\u4ee5\u4e0b\u662f\u811a\u672c\u7684\u5217\u8868\uff1a<\/p>\n<p>npm start &#8211; \u6267\u884c\u7f16\u8bd1\u5e76\u540c\u65f6\u542f\u52a8\u670d\u52a1\u5668\uff0c\u4ee5&#8221;\u76d1\u89c6\u6a21\u5f0f&#8221;\u8fd0\u884c\u3002<\/p>\n<p>npm run tsc &#8211; \u6267\u884c\u4e00\u6b21TypeScript\u7f16\u8bd1\u5668\u3002<\/p>\n<p>npm run tsc:w &#8211; \u5728\u76d1\u89c6\u6a21\u5f0f\u4e0b\u6267\u884cTypeScript\u7f16\u8bd1\u5668\u3002\u8fdb\u7a0b\u4f1a\u6301\u7eed\u8fd0\u884c\uff0c\u76d1\u89c6TypeScript\u6587\u4ef6\u7684\u66f4\u6539\uff0c\u5e76\u5728\u6587\u4ef6\u66f4\u6539\u65f6\u8fdb\u884c\u91cd\u65b0\u7f16\u8bd1\u3002<\/p>\n<p>npm run lite &#8211; \u8fd0\u884clite-server\u3002lite-server\u662f\u4e00\u4e2a\u8f7b\u91cf\u7ea7\u7684\u9759\u6001\u6587\u4ef6\u670d\u52a1\u5668\uff0c\u4e3a\u4f7f\u7528\u8def\u7531\u7684Angular\u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u63d0\u4f9b\u4e86\u51fa\u8272\u7684\u652f\u6301\u3002<\/p>\n<p>npm run typings &#8211; \u53ef\u4ee5\u5355\u72ec\u8fd0\u884ctypings\u5de5\u5177\u3002<\/p>\n<p>npm run postinstall &#8211; \u5728npm\u6210\u529f\u5b89\u88c5\u5305\u65f6\u8c03\u7528\u3002\u6b64\u811a\u672c\u5c06\u5b89\u88c5typings.json\u4e2d\u5b9a\u4e49\u7684TypeScript\u5b9a\u4e49\u6587\u4ef6\u3002<\/p><\/blockquote>\n<p>\u6211\u4eec\u5df2\u7ecf\u51c6\u5907\u597d\u4e86\uff0c\u73b0\u5728\u8ba9\u6211\u4eec\u5f00\u59cb\u7f16\u5199\u4e00\u4e9b\u4ee3\u7801\u5427\u3002<\/p>\n<h2>\u6b65\u9aa42\uff1a\u6700\u521d\u7684Angular\u7ec4\u4ef6<\/h2>\n<p>\u90a3\u4e48\uff0c\u6211\u4eec\u6765\u521b\u5efa\u4e00\u4e2a\u5305\u542b\u6211\u4eec\u5e94\u7528\u7a0b\u5e8f\u7684\u6587\u4ef6\u5939\u3002\u7136\u540e\uff0c\u8ba9\u6211\u4eec\u521b\u5efa\u4e00\u4e2a\u975e\u5e38\u7b80\u5355\u7684Angular\u7ec4\u4ef6\u3002<\/p>\n<p>\u8bf7\u5728\u9879\u76ee\u7684\u6839\u76ee\u5f55\u4e0b\u6dfb\u52a0\u4e00\u4e2a\u5b50\u6587\u4ef6\u5939\uff0c\u7528\u4e8e\u5e94\u7528\u7a0b\u5e8f\u3002<\/p>\n<pre class=\"post-pre\"><code>&gt; mkdir app\r\n\r\n<\/code><\/pre>\n<p>\u5728\u65b0\u6dfb\u52a0\u7684\u6587\u4ef6\u5939\u4e2d\uff0c\u4f7f\u7528\u4ee5\u4e0b\u5185\u5bb9\u521b\u5efaapp\/app.component.ts\u6587\u4ef6\u3002<\/p>\n<pre class=\"post-pre\"><code>\r\n    <span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">Component<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">@angular\/core<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">@<\/span><span class=\"nd\">Component<\/span><span class=\"p\">({<\/span>\r\n      <span class=\"na\">selector<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">my-app<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n      <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">&lt;h1&gt;My First Angular 2 App&lt;\/h1&gt;<\/span><span class=\"dl\">'<\/span>\r\n    <span class=\"p\">})<\/span>\r\n    <span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">AppComponent<\/span> <span class=\"p\">{<\/span> <span class=\"p\">}<\/span>\r\n\r\n<\/code><\/pre>\n<blockquote><p>AppComponent\u662f\u5e94\u7528\u7a0b\u5e8f\u7684\u6839\u3002<\/p>\n<p>\u6240\u6709\u7684Angular\u5e94\u7528\u7a0b\u5e8f\u81f3\u5c11\u6709\u4e00\u4e2a\u6839\u7ec4\u4ef6\u3002\u901a\u5e38\uff0c\u6839\u7ec4\u4ef6\u88ab\u547d\u540d\u4e3aAppComponent\u3002\u6839\u7ec4\u4ef6\u6258\u7ba1\u5ba2\u6237\u7aef\u7684\u7528\u6237\u4f53\u9a8c\u3002\u7ec4\u4ef6\u662fAngular\u5e94\u7528\u7a0b\u5e8f\u7684\u57fa\u672c\u6784\u5efa\u5757\u3002\u7ec4\u4ef6\u901a\u8fc7\u5173\u8054\u7684\u6a21\u677f\u63a7\u5236\u5c4f\u5e55\u7684\u4e00\u90e8\u5206\uff0c\u5373\u89c6\u56fe\u3002<\/p>\n<p>QuickStart\u53ea\u6709\u4e00\u4e2a\u975e\u5e38\u7b80\u5355\u7684\u7ec4\u4ef6\u3002\u4f46\u5b83\u5177\u6709\u5bf9\u4e8e\u6240\u6709\u7ec4\u4ef6\u6765\u8bf4\u662f\u5fc5\u9700\u7684\u7ed3\u6784\u3002<\/p>\n<p>\u4f7f\u7528\u4e00\u4e2a\u6216\u591a\u4e2aimport\u8bed\u53e5\u6765\u5f15\u7528\u6211\u4eec\u6240\u9700\u7684\u5185\u5bb9\u3002<\/p>\n<p>@Component\u88c5\u9970\u5668\u6307\u793aAngular\u4f7f\u7528\u54ea\u4e2a\u6a21\u677f\uff0c\u4ee5\u53ca\u5982\u4f55\u751f\u6210\u7ec4\u4ef6\u3002<\/p>\n<p>\u7ec4\u4ef6\u7c7b\u901a\u8fc7\u6a21\u677f\u63a7\u5236\u89c6\u56fe\u7684\u663e\u793a\u548c\u884c\u4e3a\u3002<\/p>\n<p>\u5bfc\u5165<\/p>\n<p>Angular\u5e94\u7528\u7a0b\u5e8f\u662f\u6a21\u5757\u3002\u6a21\u5757\u7531\u51e0\u4e2a\u6587\u4ef6\u7ec4\u6210\uff0c\u7528\u4e8e\u5b9e\u73b0\u7279\u5b9a\u76ee\u6807\u3002Angular\u672c\u8eab\u4e5f\u662f\u4e00\u4e2a\u6a21\u5757\u3002Angular\u662f\u7531\u4e00\u7cfb\u5217\u76f8\u5173\u529f\u80fd\u7684\u5e93\u6a21\u5757\u7ec4\u6210\uff0c\u7528\u4e8e\u6784\u5efa\u5e94\u7528\u7a0b\u5e8f\u3002<\/p>\n<p>\u5f53\u9700\u8981\u6a21\u5757\u6216\u5e93\u65f6\uff0c\u4f7f\u7528\u5bfc\u5165\u8bed\u53e5\u3002\u8fd9\u662fAngular 2\u6838\u5fc3\u7684\u5bfc\u5165\u3002\u8fd9\u6837\uff0c\u7ec4\u4ef6\u7684\u4ee3\u7801\u5c31\u53ef\u4ee5\u8bbf\u95ee@Component\u88c5\u9970\u5668\u4e86\u3002<\/p>\n<p>&#8220;`app\/app.component.ts\uff08\u5bfc\u5165\uff09<\/p>\n<p>import { Component } from &#8216;@angular\/core&#8217;;<\/p>\n<p>### @Component\u88c5\u9970\u5668<\/p>\n<p>\u7ec4\u4ef6\u662f\u88c5\u9970\u5668\u51fd\u6570\u3002\u8be5\u51fd\u6570\u63a5\u53d7\u4e00\u4e2a\u5143\u6570\u636e\u5bf9\u8c61\u4f5c\u4e3a\u53c2\u6570\u3002\u901a\u8fc7\u5177\u6709@\u7b26\u53f7\u7684\u88c5\u9970\u5668\u51fd\u6570\u7684\u524d\u7f00\uff0c\u5c06\u8be5\u51fd\u6570\u5e94\u7528\u4e8e\u7ec4\u4ef6\u7c7b\uff0c\u5e76\u5c06\u5143\u6570\u636e\u4f5c\u4e3a\u5bf9\u8c61\u4e00\u8d77\u8c03\u7528\u3002\u8fd9\u662f\u4e0a\u9762\u63d0\u5230\u7684\u7c7b\u3002<\/p>\n<p>@Component\u88c5\u9970\u5668\u4f7f\u7ec4\u4ef6\u7c7b\u4e0e\u5177\u6709\u5143\u6570\u636e\u7684\u88c5\u9970\u5668\uff08decoration\uff09\u76f8\u5173\u8054\uff0c\u4ee5\u6307\u793aAngular\u5982\u4f55\u751f\u6210\u548c\u4f7f\u7528\u8be5\u7ec4\u4ef6\u3002<\/p>\n<p>&#8220;`app\/app.component.ts\uff08\u5143\u6570\u636e\uff09<\/p>\n<p>@Component({<br \/>\nselector: &#8216;my-app&#8217;,<br \/>\ntemplate: &#8216;<\/p>\n<h1>My First Angular 2 App<\/h1>\n<p>&#8216;<br \/>\n})<\/p>\n<p>\u8fd9\u4e2a\u7279\u6b8a\u7684\u5143\u6570\u636e\u5bf9\u8c61\u6709\u4e24\u4e2a\u5b57\u6bb5\uff1aselector\u548ctemplate\u3002<\/p>\n<p>selector\u6307\u5b9a\u4e00\u4e2a\u7b80\u5355\u7684CSS\u9009\u62e9\u5668\uff0c\u7528\u4e8e\u8868\u793a\u8be5\u7ec4\u4ef6\u7684HTML\u5143\u7d20\u3002<\/p>\n<p>\u8be5\u7ec4\u4ef6\u5bf9\u5e94\u7684\u5143\u7d20\u88ab\u547d\u540d\u4e3amy-app\u3002\u5f53Angular\u5728\u6258\u7ba1\u7684HTML\u4e2d\u627e\u5230my-app\u5143\u7d20\u65f6\uff0c\u5b83\u5c06\u751f\u6210AppComponent\u7684\u5b9e\u4f8b\u5e76\u663e\u793a\u5b83\u3002<\/p>\n<p>template\u6307\u5b9a\u4e0e\u7ec4\u4ef6\u5173\u8054\u7684\u6a21\u677f\u3002\u5b83\u4ee5\u6269\u5c55HTML\u5f62\u5f0f\u7f16\u5199\uff0c\u6307\u793aAngular\u5982\u4f55\u5448\u73b0\u7ec4\u4ef6\u7684\u89c6\u56fe\u3002<\/p>\n<p>\u8fd9\u4e2a\u6a21\u677f\u53ea\u6709\u4e00\u884cHTML\uff0c\u663e\u793a&#8221;My First Angular 2 App&#8221;\u3002<\/p>\n<p>\u66f4\u590d\u6742\u7684\u6a21\u677f\u53ef\u80fd\u5305\u542b\u5bf9\u7ec4\u4ef6\u5c5e\u6027\u7684\u6570\u636e\u7ed1\u5b9a\uff0c\u6216\u8005\u6307\u5b9a\u5177\u6709\u5176\u4ed6\u6a21\u677f\u7684\u5e94\u7528\u7a0b\u5e8f\u7ec4\u4ef6\u3002\u8fd9\u4e9b\u6a21\u677f\u4e5f\u53ef\u4ee5\u6307\u5b9a\u5176\u4ed6\u7ec4\u4ef6\u3002\u901a\u8fc7\u8fd9\u79cd\u65b9\u5f0f\uff0cAngular\u5e94\u7528\u7a0b\u5e8f\u5f62\u6210\u4e86\u7ec4\u4ef6\u6811\u3002<\/p>\n<p>\u7ec4\u4ef6\u7c7b<\/p>\n<p>\u6587\u4ef6\u672b\u5c3e\u6709\u4e00\u4e2a\u540d\u4e3aAppComponent\u7684\u7a7a\u7c7b\u3002<\/p>\n<p>&#8220;`app\/app.component.ts\uff08\u7c7b\uff09<\/p>\n<p>export class AppComponent { }<\/p>\n<p>\u5f53\u6211\u4eec\u5f00\u59cb\u6784\u5efa\u5927\u578b\u5e94\u7528\u7a0b\u5e8f\u65f6\uff0c\u53ef\u4ee5\u901a\u8fc7\u5728\u8be5\u7c7b\u4e2d\u6dfb\u52a0\u5c5e\u6027\u548c\u5e94\u7528\u7a0b\u5e8f\u903b\u8f91\u6765\u6269\u5c55\u5b83\u3002AppComponent\u7c7b\u4e3a\u7a7a\uff0c\u56e0\u4e3a\u5728QuickStart\u4e2d\u6ca1\u6709\u5fc5\u8981\u505a\u4efb\u4f55\u4e8b\u60c5\u3002<\/p>\n<p>\u6211\u4eec\u5c06AppComponent\u5bfc\u51fa\uff0c\u5e76\u53ef\u4ee5\u5728\u5e94\u7528\u7a0b\u5e8f\u7684\u5176\u4ed6\u4f4d\u7f6e\u5bfc\u5165\u5b83\u3002\u5f53\u521b\u5efamain.ts\u65f6\u4f1a\u770b\u5230\u5b83\u3002<\/p><\/blockquote>\n<h2>\u7b2c\u4e09\u6b65\uff1a\u6dfb\u52a0main.ts\u6587\u4ef6<\/h2>\n<p>\u8bf7\u4f7f\u7528\u4ee5\u4e0b\u5185\u5bb9\u5728app\/main.ts\u6587\u4ef6\u4e2d\u52a0\u8f7dAngular\u7684\u6839\u7ec4\u4ef6\u3002<\/p>\n<pre class=\"post-pre\"><code>\r\n    <span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">bootstrap<\/span> <span class=\"p\">}<\/span>    <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">@angular\/platform-browser-dynamic<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">AppComponent<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">.\/app.component<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nx\">bootstrap<\/span><span class=\"p\">(<\/span><span class=\"nx\">AppComponent<\/span><span class=\"p\">);<\/span>\r\n\r\n<\/code><\/pre>\n<blockquote><p>\u4e3a\u4e86\u542f\u52a8\u5e94\u7528\u7a0b\u5e8f\uff0c\u9700\u8981\u5bfc\u5165\u4e24\u4e2a\u4e1c\u897f\u3002<\/p>\n<p>Angular\u7684\u6d4f\u89c8\u5668\u5f15\u5bfc\u51fd\u6570<br \/>\n\u5e94\u7528\u7a0b\u5e8f\u7684\u6839\u7ec4\u4ef6\uff0cAppComponent<\/p>\n<p>\u7136\u540e\uff0c\u4e0eAppComponent\u4e00\u8d77\u8c03\u7528bootstrap\u3002<\/p>\n<p>bootstrap\u5728\u5e73\u53f0\u4e0a\u662f\u7279\u5b9a\u7684\u3002<\/p>\n<p>\u6211\u4eec\u4ece@angular\/platform-browser-dynamic\u800c\u4e0d\u662f@angular\/core\u5bfc\u5165\u4e86\u5f15\u5bfc\u51fd\u6570\u3002\u8fd9\u662f\u56e0\u4e3a\u5f15\u5bfc\u4e0d\u662f\u6838\u5fc3\u7684\u3002\u56e0\u4e3a\u542f\u52a8\u5e94\u7528\u7a0b\u5e8f\u7684\u65b9\u6cd5\u4e0d\u6b62\u4e00\u79cd\u3002\u5b9e\u9645\u4e0a\uff0c\u5927\u591a\u6570\u5728\u6d4f\u89c8\u5668\u4e2d\u8fd0\u884c\u7684\u5e94\u7528\u7a0b\u5e8f\u90fd\u4f1a\u8c03\u7528\u6b64\u5e93\u7684\u5f15\u5bfc\u51fd\u6570\u3002<\/p>\n<p>\u7136\u800c\uff0c\u6211\u4eec\u4e5f\u53ef\u4ee5\u5c06\u7ec4\u4ef6\u52a0\u8f7d\u5230\u4e0d\u540c\u7684\u73af\u5883\u4e2d\u3002\u6211\u4eec\u53ef\u80fd\u4f1a\u5728Apache Cordova\u6216NativeScript\u4e2d\u52a0\u8f7d\u5b83\u3002\u6211\u4eec\u53ef\u80fd\u5e0c\u671b\u5728\u670d\u52a1\u5668\u4e0a\u6e32\u67d3\u5e94\u7528\u7a0b\u5e8f\u7684\u7b2c\u4e00\u4e2a\u9875\u9762\uff0c\u4ee5\u63d0\u9ad8\u542f\u52a8\u6027\u80fd\u548cSEO\u3002\u8fd9\u4e9b\u76ee\u6807\u9700\u8981\u4e0d\u540c\u7c7b\u578b\u7684\u5f15\u5bfc\u51fd\u6570\u3002\u5b83\u4eec\u5c06\u4ece\u4e0d\u540c\u7684\u5e93\u4e2d\u5bfc\u5165\u3002<\/p>\n<p>\u4e3a\u4ec0\u4e48\u5c06main.ts\u4e0e\u5e94\u7528\u7a0b\u5e8f\u7684\u7ec4\u4ef6\u6587\u4ef6\u5206\u5f00\u521b\u5efa\uff1f<\/p>\n<p>main.ts\u548c\u5e94\u7528\u7a0b\u5e8f\u7684\u7ec4\u4ef6\u6587\u4ef6\u90fd\u5f88\u5c0f\u3002\u5728\u8fd9\u4e2a\u5feb\u901f\u5165\u95e8\u4e2d\uff0c\u5b83\u4eec\u53ea\u662f\u4e00\u4e2a\u7b80\u5355\u7684\u793a\u4f8b\u3002\u6211\u4eec\u4e5f\u53ef\u4ee5\u5c06\u8fd9\u4e24\u4e2a\u6587\u4ef6\u5408\u5e76\u4e3a\u4e00\u4e2a\uff0c\u8fd9\u6837\u53ef\u80fd\u53ef\u4ee5\u907f\u514d\u590d\u6742\u6027\u3002<\/p>\n<p>\u672c\u6587\u65e8\u5728\u5c55\u793a\u521b\u5efaAngular\u5e94\u7528\u7a0b\u5e8f\u7684\u7279\u5b9a\u65b9\u6cd5\u3002\u542f\u52a8\u5e94\u7528\u7a0b\u5e8f\u662f\u4e0e\u663e\u793a\u89c6\u56fe\u4e0d\u540c\u7684\u5173\u6ce8\u70b9\u3002\u5982\u679c\u5c06\u5173\u6ce8\u70b9\u6df7\u5408\u5728\u4e00\u8d77\uff0c\u4f1a\u53d8\u5f97\u66f4\u52a0\u590d\u6742\u3002\u53ef\u80fd\u53ef\u4ee5\u5728\u591a\u4e2a\u73af\u5883\u4e2d\u4ee5\u4e0d\u540c\u7684\u5f15\u5bfc\u65b9\u5f0f\u542f\u52a8AppComponent\u3002\u56e0\u6b64\uff0c\u6d4b\u8bd5\u7ec4\u4ef6\u53ef\u80fd\u4f1a\u66f4\u52a0\u7b80\u5355\uff0c\u56e0\u4e3a\u5b83\u4eec\u4e0d\u9700\u8981\u8fd0\u884c\u6574\u4e2a\u5e94\u7528\u7a0b\u5e8f\u3002\u4e3a\u4e86\u505a\u6b63\u786e\u7684\u4e8b\u60c5\uff0c\u5c3d\u4e00\u70b9\u52aa\u529b\u5427\u3002<\/p><\/blockquote>\n<h2>\u6b65\u9aa4\u56db\uff1a\u6dfb\u52a0index.html\u6587\u4ef6\u3002<\/h2>\n<p>\u8bf7\u5728\u9879\u76ee\u7684\u6839\u6587\u4ef6\u5939\u4e2d\u521b\u5efa\u4e00\u4e2a\u540d\u4e3aindex.html\u7684\u6587\u4ef6\uff0c\u5e76\u7c98\u8d34\u4ee5\u4e0b\u5185\u5bb9\u3002<\/p>\n<pre class=\"post-pre\"><code>\r\n    <span class=\"nt\">&lt;html&gt;<\/span>\r\n      <span class=\"nt\">&lt;head&gt;<\/span>\r\n        <span class=\"nt\">&lt;title&gt;<\/span>Angular 2 QuickStart<span class=\"nt\">&lt;\/title&gt;<\/span>\r\n        <span class=\"nt\">&lt;meta<\/span> <span class=\"na\">charset=<\/span><span class=\"s\">\"UTF-8\"<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"nt\">&lt;meta<\/span> <span class=\"na\">name=<\/span><span class=\"s\">\"viewport\"<\/span> <span class=\"na\">content=<\/span><span class=\"s\">\"width=device-width, initial-scale=1\"<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"nt\">&lt;link<\/span> <span class=\"na\">rel=<\/span><span class=\"s\">\"stylesheet\"<\/span> <span class=\"na\">href=<\/span><span class=\"s\">\"styles.css\"<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"c\">&lt;!-- 1. Load libraries --&gt;<\/span>\r\n         <span class=\"c\">&lt;!-- Polyfill(s) for older browsers --&gt;<\/span>\r\n        <span class=\"nt\">&lt;script <\/span><span class=\"na\">src=<\/span><span class=\"s\">\"node_modules\/core-js\/client\/shim.min.js\"<\/span><span class=\"nt\">&gt;&lt;\/script&gt;<\/span>\r\n        <span class=\"nt\">&lt;script <\/span><span class=\"na\">src=<\/span><span class=\"s\">\"node_modules\/zone.js\/dist\/zone.js\"<\/span><span class=\"nt\">&gt;&lt;\/script&gt;<\/span>\r\n        <span class=\"nt\">&lt;script <\/span><span class=\"na\">src=<\/span><span class=\"s\">\"node_modules\/reflect-metadata\/Reflect.js\"<\/span><span class=\"nt\">&gt;&lt;\/script&gt;<\/span>\r\n        <span class=\"nt\">&lt;script <\/span><span class=\"na\">src=<\/span><span class=\"s\">\"node_modules\/systemjs\/dist\/system.src.js\"<\/span><span class=\"nt\">&gt;&lt;\/script&gt;<\/span>\r\n        <span class=\"c\">&lt;!-- 2. Configure SystemJS --&gt;<\/span>\r\n        <span class=\"nt\">&lt;script <\/span><span class=\"na\">src=<\/span><span class=\"s\">\"systemjs.config.js\"<\/span><span class=\"nt\">&gt;&lt;\/script&gt;<\/span>\r\n        <span class=\"nt\">&lt;script&gt;<\/span>\r\n          <span class=\"nx\">System<\/span><span class=\"p\">.<\/span><span class=\"k\">import<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">app<\/span><span class=\"dl\">'<\/span><span class=\"p\">).<\/span><span class=\"k\">catch<\/span><span class=\"p\">(<\/span><span class=\"kd\">function<\/span><span class=\"p\">(<\/span><span class=\"nx\">err<\/span><span class=\"p\">){<\/span> <span class=\"nx\">console<\/span><span class=\"p\">.<\/span><span class=\"nx\">error<\/span><span class=\"p\">(<\/span><span class=\"nx\">err<\/span><span class=\"p\">);<\/span> <span class=\"p\">});<\/span>\r\n        <span class=\"nt\">&lt;\/script&gt;<\/span>\r\n      <span class=\"nt\">&lt;\/head&gt;<\/span>\r\n      <span class=\"c\">&lt;!-- 3. Display the application --&gt;<\/span>\r\n      <span class=\"nt\">&lt;body&gt;<\/span>\r\n        <span class=\"nt\">&lt;my-app&gt;<\/span>Loading...<span class=\"nt\">&lt;\/my-app&gt;<\/span>\r\n      <span class=\"nt\">&lt;\/body&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/html&gt;<\/span>\r\n<\/code><\/pre>\n<blockquote><p>index.html\u6587\u4ef6\u5b9a\u4e49\u4e86\u6258\u7ba1web\u9875\u9762\u7684\u5e94\u7528\u7a0b\u5e8f\u3002\u503c\u5f97\u6ce8\u610f\u7684HTML\u90e8\u5206\u662f\uff1a<\/p>\n<p>JavaScript\u5e93<\/p>\n<p>SystemJS\u914d\u7f6e\u6587\u4ef6\u811a\u672c\u5f15\u7528\u4e86\u6211\u4eec\u4e4b\u524d\u5199\u7684main\u6587\u4ef6\uff0c\u6307\u5b9a\u4e86\u4ece\u54ea\u91cc\u5bfc\u5165\u548c\u6267\u884c\u5e94\u7528\u7a0b\u5e8f\u7684\u6a21\u5757\u3002<\/p>\n<p>\u4e2d\u7684\u6807\u7b7e\u6307\u793a\u5e94\u7528\u7a0b\u5e8f\u5728\u54ea\u91cc\u8fd0\u884c\u3002<\/p>\n<p>\u5e93<\/p>\n<p>\u5728index.html\u4e2d\u52a0\u8f7d\u4ee5\u4e0b\u811a\u672c\uff1a<\/p>\n<p>&#8220;`<br \/>\nindex.html\uff08\u5e93\uff09<\/p>\n<p><!-- Polyfill(s) for older browsers --><\/p>\n<p>core-js\u7684ES2015\/ES6 shim\u662f\u4ece\u8fd9\u91cc\u5f00\u59cb\u7684\u3002\u8be5\u6587\u4ef6\u5c06\u5728\u5168\u5c40\u4e0a\u4e0b\u6587\uff08window\uff09\u4e2d\u5e94\u7528ES2015\uff08ES6\uff09\u7684\u91cd\u8981\u529f\u80fd\u7684monkey patch\u3002\u7136\u540e\uff0czone.js\u548creflect-metadata\u662fAngular2\u7684polyfill\u3002\u7136\u540e\u662f\u7528\u4e8e\u6a21\u5757\u52a0\u8f7d\u7684[SystemJS](https:\/\/angular.io\/docs\/ts\/latest\/quickstart.html#systemjs)\u5e93\u3002<\/p>\n<p>\u5982\u679c\u60a8\u5173\u5fc3\u63d0\u9ad8\u7528\u6237\u4f53\u9a8c\u3001\u52a0\u8f7d\u65f6\u95f4\u548c\u5185\u5b58\u5360\u7528\u7b49\u4ea7\u54c1\u8d28\u91cf\uff0c\u5219\u53ef\u4ee5\u4f7f\u7528\u5176\u4ed6\u9009\u9879\u3002<\/p>\n<p>SystemJS<\/p>\n<p>QuickStart\u4f7f\u7528[SystemJS](https:\/\/github.com\/systemjs\/systemjs)\u6765\u52a0\u8f7d\u5e94\u7528\u7a0b\u5e8f\u548c\u5e93\u7684\u6a21\u5757\u3002\u8fd8\u6709\u5176\u4ed6\u66ff\u4ee3\u65b9\u6cd5\uff0c\u5305\u62ec\u503c\u5f97\u4fe1\u8d56\u7684[webpack](https:\/\/angular.io\/docs\/ts\/latest\/guide\/webpack.html)\u3002SystemJS\u53ea\u662f\u4e00\u4e2a\u597d\u7684\u9009\u62e9\u3002\u4f46\u662f\u6211\u5e0c\u671b\u660e\u786e\u6307\u51fa\u5b83\u53ea\u662f\u4e00\u79cd\u9009\u62e9\uff0c\u800c\u4e0d\u662f\u6bcf\u4e2a\u4eba\u7684\u9996\u9009\u3002<\/p>\n<p>\u6bcf\u4e2a\u6a21\u5757\u52a0\u8f7d\u5668\u90fd\u9700\u8981\u4e00\u4e9b\u914d\u7f6e\uff0c\u4efb\u4f55\u52a0\u8f7d\u5668\u7684\u914d\u7f6e\u90fd\u4f1a\u968f\u7740\u6587\u4ef6\u7ed3\u6784\u7684\u591a\u6837\u5316\u800c\u53d8\u5f97\u590d\u6742\uff0c\u5e76\u4e14\u9700\u8981\u8003\u8651\u6784\u5efa\u4ea7\u54c1\u548c\u6027\u80fd\u3002<\/p>\n<p>\u6211\u5efa\u8bae\u60a8\u719f\u6089\u6240\u9009\u52a0\u8f7d\u5668\u3002\u5982\u679c\u60a8\u60f3\u4e86\u89e3\u6709\u5173SystemJS\u914d\u7f6e\u7684\u66f4\u591a\u4fe1\u606f\uff0c\u8bf7\u8bbf\u95ee[\u8fd9\u91cc](https:\/\/github.com\/systemjs\/systemjs\/blob\/master\/docs\/config-api.md)\u3002<\/p>\n<p>\u8bf7\u8bb0\u4f4f\u8fd9\u4e9b\u6ce8\u610f\u4e8b\u9879\uff0c\u90a3\u4e48\u5728[\u4e4b\u524d\u6dfb\u52a0\u7684QuickStart\u4e2d\u7684systemjs.config.js\u914d\u7f6e\u6587\u4ef6](AddFiles)\u4e2d\uff0c\u6211\u4eec\u505a\u4e86\u4ec0\u4e48\u5462\uff1f\u9996\u5148\uff0c\u6211\u4eec\u521b\u5efa\u4e86\u4e00\u4e2a\u6620\u5c04\uff0c\u544a\u8bc9SystemJS\u5728\u5bfc\u5165\u67d0\u4e2a\u6a21\u5757\u65f6\u8981\u67e5\u627e\u7684\u4f4d\u7f6e\u3002\u7136\u540e\uff0c\u6211\u4eec\u5728SystemJS\u4e2d\u6ce8\u518c\u4e86\u6211\u4eec\u6240\u6709\u7684\u5305\uff0c\u5373\u9879\u76ee\u6240\u4f9d\u8d56\u7684\u6240\u6709\u5305\u4ee5\u53ca\u6211\u4eec\u5e94\u7528\u7a0b\u5e8f\u7684\u5305\uff0c\u5373app\u3002<\/p>\n<p>\u5c3d\u7ba1\u6211\u4eec\u7684QuickStart\u4e0d\u4f1a\u4f7f\u7528\u5217\u51fa\u7684\u6240\u6709\u5305\uff0c\u4f46\u5728\u5927\u578b\u5e94\u7528\u7a0b\u5e8f\u4e2d\uff0c\u5b83\u4eec\u4e2d\u7684\u8bb8\u591a\u90fd\u662f\u5fc5\u9700\u7684\u3002\u81f3\u5c11\u5728\u4e00\u4e2a\u793a\u4f8b\u6587\u6863\u4e2d\uff0c\u6240\u6709\u8fd9\u4e9b\u5305\u90fd\u662f\u5fc5\u9700\u7684\u3002<\/p>\n<p>\u5173\u4e8e\u5217\u51fa\u5305\uff0c\u4e0d\u9700\u8981\u7684\u5305\u53ea\u6709\u5728\u8bf7\u6c42\u65f6\u624d\u4f1a\u52a0\u8f7d\uff0c\u5bf9\u8fd0\u884c\u65f6\u6ca1\u6709\u5371\u5bb3\u3002<br \/>\n&#8220;`<\/p>\n<p>\u5f53\u5728SystemJS\u4e2d\u8bf7\u6c42\u6765\u81eaapp\/\u6587\u4ef6\u5939\u6a21\u5757\u65f6\uff0capp\u5305\u4f1a\u6307\u793aSystemJS\u5e94\u8be5\u600e\u4e48\u505a\u3002<\/p>\n<p>\u5728\u6211\u4eec\u7684QuickStart\u4e2d\uff0c\u5982\u679c\u5e94\u7528\u7a0b\u5e8f\u7684TypeScript\u6587\u4ef6\u6709\u4ee5\u4e0b\u5bfc\u5165\u58f0\u660e\uff0c\u5b83\u5c06\u53d1\u8d77\u8fd9\u6837\u7684\u8bf7\u6c42\u3002<\/p>\n<p>&#8220;`<br \/>\napp\/main.ts\uff08import\uff09<\/p>\n<p>import { AppComponent } from &#8216;.\/app.component&#8217;;<\/p>\n<p>\u8bf7\u6ce8\u610f\u6a21\u5757\u540d\u79f0\u4e0d\u5305\u542b\u6587\u4ef6\u6269\u5c55\u540d\u3002\u914d\u7f6e\u6587\u4ef6\u4e2d\u6307\u793aSystemJS\u4f7f\u7528\u9ed8\u8ba4\u6269\u5c55\u540djs\uff0c\u5373JavaScript\u3002<\/p>\n<p>\u5728\u8fd0\u884c\u5e94\u7528\u7a0b\u5e8f\u4e4b\u524d\uff0c\u6211\u4eec\u5c06TypeScript\u7f16\u8bd1\u4e3aJavaScript\uff0c\u56e0\u6b64\u4f7f\u7528ts\u7f16\u5199\u6a21\u5757\u5e76\u52a0\u8f7djs\u662f\u5408\u7406\u7684\u3002<\/p>\n<p>\u5728\u6d4f\u89c8\u5668\u4e2d\u8fdb\u884c\u7f16\u8bd1<\/p>\n<p>\u5728plunker\u7684\u53ef\u6267\u884c\u793a\u4f8b\u4e2d\uff0c\u6211\u4eec\u5728\u6d4f\u89c8\u5668\u4e2d\u8fdb\u884c\u4e86\u5bf9JavaScript\u7684\u7f16\u8bd1\u3002\u8fd9\u5bf9\u4e8e\u6f14\u793a\u6765\u8bf4\u662f\u4e00\u4e2a\u597d\u4e8b\u3002<\/p>\n<p>\u4f46\u662f\uff0c\u5728\u5f00\u53d1\u8fc7\u7a0b\u4e2d\uff0c\u8bf7\u4e0d\u8981\u5728\u6d4f\u89c8\u5668\u4e2d\u8fdb\u884c\u7f16\u8bd1\u4ea7\u54c1\u5316\u7684\u5e94\u7528\u7a0b\u5e8f\u3002<\/p>\n<p>\u5f3a\u70c8\u5efa\u8bae\u5728\u6784\u5efa\u9636\u6bb5\u6267\u884cJavaScript\u7f16\u8bd1\uff08\u5373\u7f16\u8bd1\uff09\u4e4b\u524d\u5bf9JavaScript\u8fdb\u884c\u7f16\u8bd1\u3002\u4ee5\u4e0b\u662f\u539f\u56e0\uff1a<\/p>\n<p>\u60a8\u53ef\u4ee5\u770b\u5230\u7f16\u8bd1\u5668\u7684\u8b66\u544a\u548c\u9519\u8bef\u3002\u5b83\u4eec\u5728\u6d4f\u89c8\u5668\u4e2d\u662f\u9690\u85cf\u7684\u3002<br \/>\n\u9884\u5148\u7f16\u8bd1\u7b80\u5316\u4e86\u6a21\u5757\u52a0\u8f7d\u8fc7\u7a0b\u3002\u5f53\u7f16\u8bd1\u662f\u4e00\u4e2a\u72ec\u7acb\u7684\u5916\u90e8\u6b65\u9aa4\u65f6\uff0c\u6545\u969c\u6392\u67e5\u5c31\u53d8\u5f97\u66f4\u52a0\u5bb9\u6613\u3002<br \/>\n\u9884\u5148\u7f16\u8bd1\u4f1a\u5bfc\u81f4\u66f4\u5feb\u7684\u7528\u6237\u4f53\u9a8c\u3002\u56e0\u4e3a\u4e0d\u9700\u8981\u6d4f\u89c8\u5668\u7f16\u8bd1\uff0c\u6d88\u9664\u4e86\u7f16\u8bd1\u6240\u9700\u7684\u65f6\u95f4\u3002<\/p>\n<p>\u53ea\u7f16\u8bd1\u5df2\u66f4\u6539\u7684\u6587\u4ef6\uff0c\u52a0\u5feb\u4e86\u5f00\u53d1\u901f\u5ea6\u3002\u5373\u4f7f\u6211\u4eec\u7684\u5e94\u7528\u7a0b\u5e8f\u53d8\u5f97\u975e\u5e38\u5e9e\u5927\uff0c\u6211\u4eec\u4e5f\u53ef\u4ee5\u7acb\u5373\u6ce8\u610f\u5230\u5dee\u5f02\u3002<\/p>\n<p>\u9884\u7f16\u8bd1\u975e\u5e38\u9002\u5408\u6301\u7eed\u96c6\u6210\u8fc7\u7a0b\u3001\u6784\u5efa\u3001\u6d4b\u8bd5\u548c\u90e8\u7f72\u3002<br \/>\n&#8220;`<\/p>\n<p>System.import\u662f\u6307\u793aSystemJS\u4ece\u542f\u52a8\u5e94\u7528\u7a0b\u5e8f\u65f6\u6307\u5b9a\u7684\u8def\u5f84\u52a0\u8f7d\u5e94\u7528\u7a0b\u5e8f\u7684\u4e3b\u6587\u4ef6\uff08ma.js\u3001main.ts\u60a8\u8fd8\u8bb0\u5f97\u5417\uff1f\uff09\u3002\u5728\u542f\u52a8\u65f6\uff0c\u53ef\u4ee5\u5728\u63a7\u5236\u53f0\u4e2d\u83b7\u53d6\u542f\u52a8\u65f6\u7684\u65e5\u5fd7\u548c\u9519\u8bef\u3002<\/p>\n<p>\u6240\u6709\u5176\u4ed6\u6a21\u5757\u90fd\u662f\u901a\u8fc7\u52a0\u8f7d\u3001import\u8bed\u53e5\u7684\u8bf7\u6c42\u6216Angular\u672c\u8eab\u7684\u8bf7\u6c42\u6765\u52a0\u8f7d\u7684\u3002<\/p>\n<p>&nbsp;<\/p>\n<p>\u5f53Angular\u8c03\u7528main.ts\u7684\u5f15\u5bfc\u51fd\u6570\u65f6\uff0cAngular\u4f1a\u8bfb\u53d6AppComponent\u7684\u5143\u6570\u636e\uff0c\u5bfb\u627emy-app\u9009\u62e9\u5668\uff0c\u5e76\u627e\u5230\u540d\u4e3amy-app\u7684\u6807\u7b7e\u5143\u7d20\uff0c\u7136\u540e\u6e32\u67d3\u8be5\u6807\u7b7e\u4e4b\u95f4\u7684\u5e94\u7528\u7a0b\u5e8f\u89c6\u56fe\u3002<\/p><\/blockquote>\n<h3>\u6dfb\u52a0\u6837\u5f0f<\/h3>\n<p>\u6837\u5f0f\u4e0d\u662f\u5fc5\u9700\u7684\uff0c\u4f46\u5f88\u597d\u3002\u6211\u4eec\u4e5f\u9700\u8981\u51c6\u5907\u4e00\u4e2a\u79f0\u4e3astyles.css\u7684\u6837\u5f0f\u8868\u5728index.html\u4e2d\u4f7f\u7528\u3002<\/p>\n<p>\u8bf7\u5728\u9879\u76ee\u7684\u6839\u6587\u4ef6\u5939\u4e2d\u521b\u5efastyles.css\u6587\u4ef6\u3002\u73b0\u5728\u6211\u4eec\u53ef\u4ee5\u5f00\u59cb\u6837\u5f0f\u5316\u4e86\u3002\u4e5f\u8bb8\u4ece\u4ee5\u4e0b\u6700\u57fa\u672c\u7684\u6837\u5f0f\u5f00\u59cb\u4f1a\u66f4\u597d\u3002\u5982\u9700\u4f7f\u7528\u793a\u4f8b\u6587\u6863\u4e2d\u7684\u5b8c\u6574\u4e3b\u6837\u5f0f\u96c6\uff0c\u8bf7\u53c2\u8003styles.css\u6587\u4ef6\u3002<\/p>\n<p>styles.css\uff08\u6458\u5f55\uff09<\/p>\n<p>h1 {<br \/>\n\u989c\u8272\uff1a#369;<br \/>\n\u5b57\u4f53\u65cf\uff1aArial, Helvetica, sans-serif;<br \/>\n\u5b57\u4f53\u5927\u5c0f\uff1a250%;<br \/>\n}<br \/>\nbody {<br \/>\n\u5916\u8fb9\u8ddd\uff1a2em;<br \/>\n}<\/p>\n<p>\u8bf7\u53c2\u89c1https:\/\/github.com\/angular\/angular.io\/blob\/master\/public\/docs\/_examples\/styles.css\u4ee5\u67e5\u770b\u6587\u6863\u793a\u4f8b\u6240\u4f7f\u7528\u7684\u5b8c\u6574\u4e3b\u6837\u5f0f\u96c6\u3002<\/p>\n<pre class=\"post-pre\"><code>\r\n## Step 5: \u30a2\u30d7\u30ea\u306e\u30d3\u30eb\u30c9\u3068\u5b9f\u884c! &lt;a name=\"Step5\" \/&gt;\r\n\r\n\u30bf\u30fc\u30df\u30ca\u30eb\u30a6\u30a3\u30f3\u30c9\u30a6\u3092\u958b\u3044\u3066\u3001\u3053\u3061\u3089\u306e\u30b3\u30de\u30f3\u30c9\u3092\u5165\u529b\u3057\u3066\u304f\u3060\u3055\u3044\u3002\r\n\r\n<\/code><\/pre>\n<blockquote><p>\u8fd0\u884cnpm\u7684\u542f\u52a8\u547d\u4ee4\u3002<\/p><\/blockquote>\n<pre class=\"post-pre\"><code>\r\n\u3053\u306e\u30b3\u30de\u30f3\u30c9\u306f\u4e8c\u3064\u306e\u4e26\u884c\u3057\u3066node\u30d7\u30ed\u30bb\u30b9\u3092\u5b9f\u884c\u3057\u307e\u3059\u3002\r\n\r\n* TypeScript\u30b3\u30f3\u30d1\u30a4\u30e9\u3092\u76e3\u8996\u30e2\u30fc\u30c9\u3067\u5b9f\u884c\r\n* lite-server\u3068\u547c\u3070\u308c\u308b\u9759\u7684\u30b5\u30fc\u30d0\u30fc\u3000\u30d6\u30e9\u30a6\u30b6\u3067index.html\u3092\u30ed\u30fc\u30c9\u3057\u3001\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u30d5\u30a1\u30a4\u30eb\u304c\u66f4\u65b0\u3055\u308c\u305f\u6642\u306b\u30ea\u30d5\u30ec\u30c3\u30b7\u30e5\u3057\u307e\u3059\u3002\r\n\r\n\u3057\u3070\u3089\u304f\u7d4c\u3064\u3068\u3001\u30d6\u30e9\u30a6\u30b6\u30bf\u30d6\u304c\u958b\u304d\u3001QuickStart\u30a2\u30d7\u30ea\u306e\u51fa\u529b\u304c\u8868\u793a\u3055\u308c\u308b\u3067\u3057\u3087\u3046\u3002\r\n\r\nGreat job!\r\n\r\n## \u5909\u66f4\u3092\u52a0\u3048\u308b &lt;a name=\"Changes\" \/&gt;\r\n\r\n\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\"My SECOND Angular 2 app\"\u3078\u5909\u66f4\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002\r\n\r\nTypeScript\u3068lite-server\u306f\u76e3\u8996\u3057\u3066\u3044\u307e\u3059\u3002\u5909\u66f4\u3092\u691c\u77e5\u3057\u3001TypeScript\u3092JavaScript\u3078\u518d\u30b3\u30f3\u30d1\u30a4\u30eb\u3057\u3001\u30d6\u30e9\u30a6\u30b6\u3092\u66f4\u65b0\u3057\u3001\u65b0\u3057\u3044\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u8868\u793a\u3057\u307e\u3059\u3002\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u958b\u767a\u3059\u308b\u6c17\u306e\u5229\u3044\u305f\u65b9\u6cd5\u3067\u3059\u306d\uff01\r\n\r\n\u30b3\u30f3\u30d1\u30a4\u30e9\u3068\u30b5\u30fc\u30d0\u30fc\u306e\u5229\u7528\u304c\u7d42\u308f\u3063\u305f\u3089\u3001\u30bf\u30fc\u30df\u30ca\u30eb\u30a6\u30a3\u30f3\u30c9\u30a6\u3092\u9589\u3058\u3066\u304f\u3060\u3055\u3044\u3002\r\n\r\n## \u30e9\u30c3\u30d7\u30a2\u30c3\u30d7 &lt;a name=\"WrapUp\" \/&gt;\r\n\r\n\r\n\u79c1\u305f\u3061\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u30d5\u30a9\u30eb\u30c0\u69cb\u6210\u306f\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002\r\n\r\n<\/code><\/pre>\n<p>angular2-quickstart<br \/>\n+\u5e94\u7528<br \/>\n+app.component.ts<br \/>\n+main.ts<br \/>\n+node_modules &#8230;<br \/>\n+typings &#8230;<br \/>\n+index.html<br \/>\n+package.json<br \/>\n+styles.css<br \/>\n+systemjs.config.js<br \/>\n+tsconfig.json<br \/>\n+typings.json<\/p>\n<pre class=\"post-pre\"><code>\r\n\u4ee5\u4e0b\u304c\u30d5\u30a1\u30a4\u30eb\u306e\u5185\u5bb9\u3067\u3059\u3002(**\u7b46\u8005\u8a3b\uff1a\u8981\u3059\u308b\u306b\u4ee5\u4e0b\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u30b3\u30d4\u30fc\u3057\u3066\u30d5\u30a1\u30a4\u30eb\u3092\u63c3\u3048\u307e\u3057\u3087\u3046\uff01**)\r\n\r\n```app\/component.ts\r\n    import { Component } from '@angular\/core';\r\n    @Component({\r\n      selector: 'my-app',\r\n      template: '&lt;h1&gt;My First Angular 2 App&lt;\/h1&gt;'\r\n    })\r\n    export class AppComponent { }\r\n\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">bootstrap<\/span> <span class=\"p\">}<\/span>    <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">@angular\/platform-browser-dynamic<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">AppComponent<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">.\/app.component<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"nx\">bootstrap<\/span><span class=\"p\">(<\/span><span class=\"nx\">AppComponent<\/span><span class=\"p\">);<\/span>\r\n\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;html&gt;<\/span>\r\n  <span class=\"nt\">&lt;head&gt;<\/span>\r\n    <span class=\"nt\">&lt;title&gt;<\/span>Angular 2 QuickStart<span class=\"nt\">&lt;\/title&gt;<\/span>\r\n    <span class=\"nt\">&lt;meta<\/span> <span class=\"na\">charset=<\/span><span class=\"s\">\"UTF-8\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;meta<\/span> <span class=\"na\">name=<\/span><span class=\"s\">\"viewport\"<\/span> <span class=\"na\">content=<\/span><span class=\"s\">\"width=device-width, initial-scale=1\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;link<\/span> <span class=\"na\">rel=<\/span><span class=\"s\">\"stylesheet\"<\/span> <span class=\"na\">href=<\/span><span class=\"s\">\"styles.css\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"c\">&lt;!-- 1. Load libraries --&gt;<\/span>\r\n     <span class=\"c\">&lt;!-- Polyfill(s) for older browsers --&gt;<\/span>\r\n    <span class=\"nt\">&lt;script <\/span><span class=\"na\">src=<\/span><span class=\"s\">\"node_modules\/core-js\/client\/shim.min.js\"<\/span><span class=\"nt\">&gt;&lt;\/script&gt;<\/span>\r\n    <span class=\"nt\">&lt;script <\/span><span class=\"na\">src=<\/span><span class=\"s\">\"node_modules\/zone.js\/dist\/zone.js\"<\/span><span class=\"nt\">&gt;&lt;\/script&gt;<\/span>\r\n    <span class=\"nt\">&lt;script <\/span><span class=\"na\">src=<\/span><span class=\"s\">\"node_modules\/reflect-metadata\/Reflect.js\"<\/span><span class=\"nt\">&gt;&lt;\/script&gt;<\/span>\r\n    <span class=\"nt\">&lt;script <\/span><span class=\"na\">src=<\/span><span class=\"s\">\"node_modules\/systemjs\/dist\/system.src.js\"<\/span><span class=\"nt\">&gt;&lt;\/script&gt;<\/span>\r\n    <span class=\"c\">&lt;!-- 2. Configure SystemJS --&gt;<\/span>\r\n    <span class=\"nt\">&lt;script <\/span><span class=\"na\">src=<\/span><span class=\"s\">\"systemjs.config.js\"<\/span><span class=\"nt\">&gt;&lt;\/script&gt;<\/span>\r\n    <span class=\"nt\">&lt;script&gt;<\/span>\r\n      <span class=\"nx\">System<\/span><span class=\"p\">.<\/span><span class=\"k\">import<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">app<\/span><span class=\"dl\">'<\/span><span class=\"p\">).<\/span><span class=\"k\">catch<\/span><span class=\"p\">(<\/span><span class=\"kd\">function<\/span><span class=\"p\">(<\/span><span class=\"nx\">err<\/span><span class=\"p\">){<\/span> <span class=\"nx\">console<\/span><span class=\"p\">.<\/span><span class=\"nx\">error<\/span><span class=\"p\">(<\/span><span class=\"nx\">err<\/span><span class=\"p\">);<\/span> <span class=\"p\">});<\/span>\r\n    <span class=\"nt\">&lt;\/script&gt;<\/span>\r\n  <span class=\"nt\">&lt;\/head&gt;<\/span>\r\n  <span class=\"c\">&lt;!-- 3. Display the application --&gt;<\/span>\r\n  <span class=\"nt\">&lt;body&gt;<\/span>\r\n    <span class=\"nt\">&lt;my-app&gt;<\/span>Loading...<span class=\"nt\">&lt;\/my-app&gt;<\/span>\r\n  <span class=\"nt\">&lt;\/body&gt;<\/span>\r\n<span class=\"nt\">&lt;\/html&gt;<\/span>\r\n\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"p\">{<\/span>\r\n  <span class=\"nl\">\"name\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"angular2-quickstart\"<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nl\">\"version\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"1.0.0\"<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nl\">\"scripts\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"start\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"tsc &amp;&amp; concurrently <\/span><span class=\"se\">\\\"<\/span><span class=\"s2\">npm run tsc:w<\/span><span class=\"se\">\\\"<\/span> <span class=\"se\">\\\"<\/span><span class=\"s2\">npm run lite<\/span><span class=\"se\">\\\"<\/span><span class=\"s2\"> \"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"lite\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"lite-server\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"postinstall\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"typings install\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"tsc\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"tsc\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"tsc:w\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"tsc -w\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"typings\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"typings\"<\/span>\r\n  <span class=\"p\">},<\/span>\r\n  <span class=\"nl\">\"license\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"ISC\"<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nl\">\"dependencies\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"@angular\/common\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/compiler\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/core\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/http\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/platform-browser\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/platform-browser-dynamic\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/router\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/router-deprecated\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"@angular\/upgrade\"<\/span><span class=\"p\">:<\/span>  <span class=\"s2\">\"2.0.0-rc.1\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"systemjs\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"0.19.27\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"core-js\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"^2.4.0\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"reflect-metadata\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"^0.1.3\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"rxjs\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"5.0.0-beta.6\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"zone.js\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"^0.6.12\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"angular2-in-memory-web-api\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"0.0.10\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"bootstrap\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"^3.3.6\"<\/span>\r\n  <span class=\"p\">},<\/span>\r\n  <span class=\"nl\">\"devDependencies\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"concurrently\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"^2.0.0\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"lite-server\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"^2.2.0\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"typescript\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"^1.8.10\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"typings\"<\/span><span class=\"p\">:<\/span><span class=\"s2\">\"^1.0.4\"<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"p\">{<\/span>\r\n  <span class=\"nl\">\"compilerOptions\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"target\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"es5\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"module\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"commonjs\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"moduleResolution\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"node\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"sourceMap\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"emitDecoratorMetadata\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"experimentalDecorators\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"removeComments\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">false<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"noImplicitAny\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">false<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"p\">{<\/span>\r\n  <span class=\"nl\">\"globalDependencies\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"core-js\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"registry:dt\/core-js#0.0.0+20160317120654\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"jasmine\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"registry:dt\/jasmine#2.2.0+20160505161446\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"node\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"registry:dt\/node#4.0.0+20160509154515\"<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">h1<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nl\">color<\/span><span class=\"p\">:<\/span> <span class=\"m\">#369<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">font-family<\/span><span class=\"p\">:<\/span> <span class=\"n\">Arial<\/span><span class=\"p\">,<\/span> <span class=\"n\">Helvetica<\/span><span class=\"p\">,<\/span> <span class=\"nb\">sans-serif<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">font-size<\/span><span class=\"p\">:<\/span> <span class=\"m\">250%<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">body<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nl\">margin<\/span><span class=\"p\">:<\/span> <span class=\"m\">2em<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n <span class=\"c\">\/*\r\n  * See https:\/\/github.com\/angular\/angular.io\/blob\/master\/public\/docs\/_examples\/styles.css\r\n  * for the full set of master styles used by the documentation samples\r\n  *\/<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"cm\">\/**\r\n * System configuration for Angular 2 samples\r\n * Adjust as necessary for your application needs.\r\n *\/<\/span>\r\n<span class=\"p\">(<\/span><span class=\"kd\">function<\/span><span class=\"p\">(<\/span><span class=\"nb\">global<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"c1\">\/\/ map tells the System loader where to look for things<\/span>\r\n  <span class=\"kd\">var<\/span> <span class=\"nx\">map<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">app<\/span><span class=\"dl\">'<\/span><span class=\"p\">:<\/span>                        <span class=\"dl\">'<\/span><span class=\"s1\">app<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"c1\">\/\/ 'dist',<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">@angular<\/span><span class=\"dl\">'<\/span><span class=\"p\">:<\/span>                   <span class=\"dl\">'<\/span><span class=\"s1\">node_modules\/@angular<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">angular2-in-memory-web-api<\/span><span class=\"dl\">'<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">node_modules\/angular2-in-memory-web-api<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">rxjs<\/span><span class=\"dl\">'<\/span><span class=\"p\">:<\/span>                       <span class=\"dl\">'<\/span><span class=\"s1\">node_modules\/rxjs<\/span><span class=\"dl\">'<\/span>\r\n  <span class=\"p\">};<\/span>\r\n  <span class=\"c1\">\/\/ packages tells the System loader how to load when no filename and\/or no extension<\/span>\r\n  <span class=\"kd\">var<\/span> <span class=\"nx\">packages<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">app<\/span><span class=\"dl\">'<\/span><span class=\"p\">:<\/span>                        <span class=\"p\">{<\/span> <span class=\"na\">main<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">main.js<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>  <span class=\"na\">defaultExtension<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">js<\/span><span class=\"dl\">'<\/span> <span class=\"p\">},<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">rxjs<\/span><span class=\"dl\">'<\/span><span class=\"p\">:<\/span>                       <span class=\"p\">{<\/span> <span class=\"na\">defaultExtension<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">js<\/span><span class=\"dl\">'<\/span> <span class=\"p\">},<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">angular2-in-memory-web-api<\/span><span class=\"dl\">'<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span> <span class=\"na\">defaultExtension<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">js<\/span><span class=\"dl\">'<\/span> <span class=\"p\">},<\/span>\r\n  <span class=\"p\">};<\/span>\r\n  <span class=\"kd\">var<\/span> <span class=\"nx\">ngPackageNames<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">common<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">compiler<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">core<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">http<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">platform-browser<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">platform-browser-dynamic<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">router<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">router-deprecated<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"dl\">'<\/span><span class=\"s1\">upgrade<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"p\">];<\/span>\r\n  <span class=\"c1\">\/\/ Add package entries for angular packages<\/span>\r\n  <span class=\"nx\">ngPackageNames<\/span><span class=\"p\">.<\/span><span class=\"nx\">forEach<\/span><span class=\"p\">(<\/span><span class=\"kd\">function<\/span><span class=\"p\">(<\/span><span class=\"nx\">pkgName<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">packages<\/span><span class=\"p\">[<\/span><span class=\"dl\">'<\/span><span class=\"s1\">@angular\/<\/span><span class=\"dl\">'<\/span><span class=\"o\">+<\/span><span class=\"nx\">pkgName<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span> <span class=\"na\">main<\/span><span class=\"p\">:<\/span> <span class=\"nx\">pkgName<\/span> <span class=\"o\">+<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">.umd.js<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"na\">defaultExtension<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">js<\/span><span class=\"dl\">'<\/span> <span class=\"p\">};<\/span>\r\n  <span class=\"p\">});<\/span>\r\n  <span class=\"kd\">var<\/span> <span class=\"nx\">config<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"na\">map<\/span><span class=\"p\">:<\/span> <span class=\"nx\">map<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">packages<\/span><span class=\"p\">:<\/span> <span class=\"nx\">packages<\/span>\r\n  <span class=\"p\">}<\/span>\r\n  <span class=\"nx\">System<\/span><span class=\"p\">.<\/span><span class=\"nx\">config<\/span><span class=\"p\">(<\/span><span class=\"nx\">config<\/span><span class=\"p\">);<\/span>\r\n<span class=\"p\">})(<\/span><span class=\"k\">this<\/span><span class=\"p\">);<\/span>\r\n<\/code><\/pre>\n<h2>\u63a5\u4e0b\u6765\u662f\u4ec0\u4e48\uff1f<\/h2>\n<p>\u6211\u4eec\u7684\u7b2c\u4e00\u4e2a\u5e94\u7528\u7a0b\u5e8f\u5e76\u6ca1\u6709\u505a\u592a\u591a\u7684\u4e8b\u60c5\uff0c\u57fa\u672c\u4e0a\u53ea\u662fAngular 2\u7684&#8221;Hello World&#8221;\u3002<\/p>\n<p>\u6211\u4eec\u4fdd\u6301\u4e86\u6700\u521d\u7684\u5e94\u7528\u7a0b\u5e8f\u7b80\u5355\u3002\u6211\u4eec\u521b\u5efa\u4e86\u4e00\u4e2a\u5c0f\u7684Angular\u7ec4\u4ef6\uff0c\u7f16\u5199\u4e86\u4e00\u4e2a\u7b80\u5355\u7684index.html\uff0c\u5e76\u5728\u9759\u6001\u6587\u4ef6\u670d\u52a1\u5668\u4e0a\u542f\u52a8\u4e86\u5b83\u3002\u8fd9\u5c31\u662f\u6211\u4eec\u5bf9\u4e8e&#8221;Hello World&#8221;\u5e94\u7528\u7a0b\u5e8f\u7684\u671f\u671b\u3002<\/p>\n<p>\u6211\u4eec\u6709\u66f4\u5927\u7684\u96c4\u5fc3\u58ee\u5fd7\uff01<\/p>\n<p>\u597d\u6d88\u606f\u662f\uff0c\u73b0\u5728\u51e0\u4e4e\u6ca1\u6709\u8bbe\u7f6e\u5f00\u9500\u4e86\u3002\u6211\u4eec\u53ef\u4ee5\u901a\u8fc7\u4fee\u6539package.json\u6765\u66f4\u65b0\u5e93\uff0c\u7136\u540e\u5c06\u6240\u9700\u7684\u5e93\u548cCSS\u6837\u5f0f\u8868\u6dfb\u52a0\u5230index.html\u4e2d\u3002<\/p>\n<p>\u6211\u4eec\u5df2\u7ecf\u8fdb\u5165\u4e0b\u4e00\u9636\u6bb5\u4e86\u3002\u4e0b\u4e00\u6b65\u662f\u901a\u8fc7\u4f7f\u7528Angular2\u6765\u6784\u5efa\u4e00\u4e2a\u5c0f\u5e94\u7528\u7a0b\u5e8f\uff0c\u4ee5\u5c55\u793a\u6211\u4eec\u53ef\u4ee5\u6784\u5efa\u66f4\u5927\u7684\u5e94\u7528\u7a0b\u5e8f\u3002<\/p>\n<p>\u6211\u4eec\u6765\u505a\u4e00\u4e0b\u300a\u82f1\u96c4\u4e4b\u65c5\u300b\u7684\u6559\u7a0b\u5427\uff01<\/p>\n<hr \/>\n<p>\u7531Google\u63d0\u4f9b\u652f\u6301 \u00a92010-2016\u3002\u4ee3\u7801\u91c7\u7528MIT\u98ce\u683c\u8bb8\u53ef\u8bc1\u8fdb\u884c\u8bb8\u53ef\u3002\u6587\u6863\u91c7\u7528CC BY 4.0\u8bb8\u53ef\u8bc1\u8fdb\u884c\u8bb8\u53ef\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u6211\u5728Google I\/O 2016\u4e2d\u770b\u5230\u4e86\u5f88\u591a\u4f1a\u8bae\uff0c\u6211\u4e3a\u5373\u5c06\u6765\u4e34\u7684\u670d\u52a1\u5f00\u53d1\u63d0\u9ad8\u6548\u7387\u7684\u6846\u67b6Angular2\u76845\u5206 [&hellip;]<\/p>\n","protected":false},"author":5,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-39092","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>Angular2 5\u5206\u949f\u5feb\u901f\u5165\u95e8\uff08\u5e26\u6709TypeScript\u89e3\u91ca\uff09\u7684\u7ffb\u8bd1 - 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\/angular2-5\u5206\u949f\u5feb\u901f\u5165\u95e8\uff08\u5e26\u6709typescript\u89e3\u91ca\uff09\u7684\u7ffb\u8bd1\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Angular2 5\u5206\u949f\u5feb\u901f\u5165\u95e8\uff08\u5e26\u6709TypeScript\u89e3\u91ca\uff09\u7684\u7ffb\u8bd1\" \/>\n<meta property=\"og:description\" content=\"\u6211\u5728Google I\/O 2016\u4e2d\u770b\u5230\u4e86\u5f88\u591a\u4f1a\u8bae\uff0c\u6211\u4e3a\u5373\u5c06\u6765\u4e34\u7684\u670d\u52a1\u5f00\u53d1\u63d0\u9ad8\u6548\u7387\u7684\u6846\u67b6Angular2\u76845\u5206 [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/angular2-5\u5206\u949f\u5feb\u901f\u5165\u95e8\uff08\u5e26\u6709typescript\u89e3\u91ca\uff09\u7684\u7ffb\u8bd1\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-08-30T17:33:39+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-29T18:17:48+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d385b37434c4406c75b5c\/6-0.png\" \/>\n<meta name=\"author\" content=\"\u6e05, \u5b87\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u6e05, \u5b87\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"7 \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\/angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91\/\",\"name\":\"Angular2 5\u5206\u949f\u5feb\u901f\u5165\u95e8\uff08\u5e26\u6709TypeScript\u89e3\u91ca\uff09\u7684\u7ffb\u8bd1 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-08-30T17:33:39+00:00\",\"dateModified\":\"2024-04-29T18:17:48+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/1a6ecd3d914d22a5ac32791ffc1fbd8e\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Angular2 5\u5206\u949f\u5feb\u901f\u5165\u95e8\uff08\u5e26\u6709TypeScript\u89e3\u91ca\uff09\u7684\u7ffb\u8bd1\"}]},{\"@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\/1a6ecd3d914d22a5ac32791ffc1fbd8e\",\"name\":\"\u6e05, \u5b87\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/4b2016c18459a605fc469c7566608f5686491baa112d0871ee613f61b7210565?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/4b2016c18459a605fc469c7566608f5686491baa112d0871ee613f61b7210565?s=96&d=mm&r=g\",\"caption\":\"\u6e05, \u5b87\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/qingyu\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Angular2 5\u5206\u949f\u5feb\u901f\u5165\u95e8\uff08\u5e26\u6709TypeScript\u89e3\u91ca\uff09\u7684\u7ffb\u8bd1 - 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\/angular2-5\u5206\u949f\u5feb\u901f\u5165\u95e8\uff08\u5e26\u6709typescript\u89e3\u91ca\uff09\u7684\u7ffb\u8bd1\/","og_locale":"zh_CN","og_type":"article","og_title":"Angular2 5\u5206\u949f\u5feb\u901f\u5165\u95e8\uff08\u5e26\u6709TypeScript\u89e3\u91ca\uff09\u7684\u7ffb\u8bd1","og_description":"\u6211\u5728Google I\/O 2016\u4e2d\u770b\u5230\u4e86\u5f88\u591a\u4f1a\u8bae\uff0c\u6211\u4e3a\u5373\u5c06\u6765\u4e34\u7684\u670d\u52a1\u5f00\u53d1\u63d0\u9ad8\u6548\u7387\u7684\u6846\u67b6Angular2\u76845\u5206 [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/angular2-5\u5206\u949f\u5feb\u901f\u5165\u95e8\uff08\u5e26\u6709typescript\u89e3\u91ca\uff09\u7684\u7ffb\u8bd1\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-08-30T17:33:39+00:00","article_modified_time":"2024-04-29T18:17:48+00:00","og_image":[{"url":"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d385b37434c4406c75b5c\/6-0.png"}],"author":"\u6e05, \u5b87","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u6e05, \u5b87","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"7 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91\/","name":"Angular2 5\u5206\u949f\u5feb\u901f\u5165\u95e8\uff08\u5e26\u6709TypeScript\u89e3\u91ca\uff09\u7684\u7ffb\u8bd1 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-08-30T17:33:39+00:00","dateModified":"2024-04-29T18:17:48+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/1a6ecd3d914d22a5ac32791ffc1fbd8e"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"Angular2 5\u5206\u949f\u5feb\u901f\u5165\u95e8\uff08\u5e26\u6709TypeScript\u89e3\u91ca\uff09\u7684\u7ffb\u8bd1"}]},{"@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\/1a6ecd3d914d22a5ac32791ffc1fbd8e","name":"\u6e05, \u5b87","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/4b2016c18459a605fc469c7566608f5686491baa112d0871ee613f61b7210565?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/4b2016c18459a605fc469c7566608f5686491baa112d0871ee613f61b7210565?s=96&d=mm&r=g","caption":"\u6e05, \u5b87"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/qingyu\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/angular2-5%e5%88%86%e9%92%9f%e5%bf%ab%e9%80%9f%e5%85%a5%e9%97%a8%ef%bc%88%e5%b8%a6%e6%9c%89typescript%e8%a7%a3%e9%87%8a%ef%bc%89%e7%9a%84%e7%bf%bb%e8%af%91\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39092","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\/5"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=39092"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39092\/revisions"}],"predecessor-version":[{"id":89080,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39092\/revisions\/89080"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=39092"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=39092"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=39092"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}