{"id":39559,"date":"2023-07-11T17:35:46","date_gmt":"2023-09-26T10:50:28","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b\/"},"modified":"2024-04-30T13:04:29","modified_gmt":"2024-04-30T05:04:29","slug":"angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b\/","title":{"rendered":"Angular \u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u7684\u5206\u7c7b\u548c\u521b\u5efa Angular UI \u6846\u67b6\u7684\u6545\u4e8b"},"content":{"rendered":"<p>\u672c\u6587\u662f2016\u5e74Angular Advent Calendar\u7b2c21\u5929\u7684\u6587\u7ae0\u3002<\/p>\n<p>\u6211\u5728\u4eca\u5e74\u7684\u4e0b\u534a\u5e74\u5f00\u53d1\u4e86\u4e00\u4e2a\u540d\u4e3aangular2-onsenui\u7684UI\u6846\u67b6\uff0c\u4e0b\u9762\u6211\u5c06\u7b80\u8981\u4ecb\u7ecd\u5176\u89c4\u683c\u3002<br \/>\n\u9996\u5148\uff0c\u6211\u5c06\u8ba8\u8bba\u5728Angular\u5e94\u7528\u5f00\u53d1\u4e2d\u6784\u5efaUI\u7684\u6a21\u5f0f\uff0c\u4ee5\u53ca\u5982\u4f55\u4e0e\u6bcf\u4e2a\u6a21\u5f0f\u4e2d\u7684CSS\u6846\u67b6\u548cUI\u6846\u67b6\u8fdb\u884c\u914d\u5408\u3002<\/p>\n<h1>\u9996\u5148<\/h1>\n<p>Angular\u4e8e\u4eca\u5e749\u6708\u53d1\u5e03\u4e86\u7a33\u5b9a\u7248\uff082.0.0\uff09\uff0c\u4e0d\u518d\u7ecf\u5386\u7834\u574f\u6027\u7684\u6539\u53d8\u3002\u6b64\u5916\uff0c\u73b0\u5728\u5df2\u7ecf\u6709\u5f88\u591a\u5173\u4e8eAngular\u5468\u8fb9\u6982\u5ff5\u7684\u65e5\u8bed\u6587\u7ae0\uff0c\u5982TypeScript\u3001\u88c5\u9970\u5668\u3001\u5c42\u6b21\u4f9d\u8d56\u6ce8\u5165\u3001\u52a8\u753b\u6548\u679c\u3001Zone.js\u3001RxJS\u3001Ahead-of-Time\u7f16\u8bd1\u3001Angular CLI\u3001\u670d\u52a1\u5668\u7aef\u6e32\u67d3(SSR)\u7b49\u3002\u4e5f\u6709\u4e00\u4e9b\u5173\u4e8e\u5982\u4f55\u7cbe\u901a\u8fd9\u4e9b\u6982\u5ff5\u7684\u6280\u5de7\u603b\u7ed3\u51fa\u6765\u4e86\u3002<\/p>\n<p>\u6211\u8ba4\u4e3a\u5f88\u591a\u4eba\u53ef\u80fd\u5df2\u7ecf\u8fbe\u5230\u4e86\u8fd9\u4e2a\u9636\u6bb5\uff0c\u53ea\u8981\u6709\u5fc3\uff0c\u5c31\u80fd\u5236\u4f5c\u4efb\u4f55\u7ec4\u4ef6\u548c\u4efb\u4f55\u5e94\u7528\u7a0b\u5e8f\u3002<\/p>\n<p>\u7136\u800c\uff0c\u5b8c\u5168\u4ece\u96f6\u5f00\u59cb\u5b9e\u65bd\u6240\u6709\u5185\u5bb9\u662f\u4e0d\u660e\u667a\u7684\u3002\u6211\u8ba4\u4e3a\u8fd9\u4e9b\u4eba\u4f1a\u8003\u8651\u4f7f\u7528\u5e93\u6765\u8f7b\u677e\u5b8c\u6210\u4efb\u52a1\uff0c\u8fd9\u5c06\u6210\u4e3a\u4e0b\u4e00\u6b65\u3002\u6211\u8ba4\u4e3a\u660e\u5e74\u8fd9\u7c7b\u8bdd\u9898\u4f1a\u589e\u591a\u3002<\/p>\n<p>\u5728\u4f7f\u7528\u5e93\u6765\u8f7b\u677e\u5904\u7406\u7684\u5bf9\u8c61\u4e2d\uff0c\u53ef\u4ee5\u8fdb\u884c\u4e0e\u540e\u7aef\uff08\u4e91\u670d\u52a1\u3001\u672c\u5730\u670d\u52a1\u5668\u7b49\uff09\u7684\u534f\u4f5c\u548cFlux\u67b6\u6784\u7684\u5b9e\u73b0\u7b49\u3002\u4f46\u662f\uff0c\u672c\u6587\u5c06\u8ba8\u8bba\u5982\u4f55\u8f7b\u677e\u6784\u5efa\u7528\u6237\u754c\u9762\u3002<\/p>\n<h1>\u7528\u6237\u754c\u9762\u7684\u7ec4\u4ef6<\/h1>\n<p>\u53ef\u80fd\u306a\u4e2d\u56fd\u8a9e\u7ffb\u8bd1\uff1a\u6784\u6210UI\u7684\u5143\u7d20\u591a\u79cd\u591a\u6837\uff0c\u4f46\u672c\u6587\u6682\u65f6\u4ec5\u8ba8\u8bbaUI\u7684\u6784\u6210\u8981\u7d20\u3002<\/p>\n<p>\u30b9\u30bf\u30a4\u30eb:\u00a0\u00a0CSS \u3060\u3051\u3067\u5b9f\u88c5\u3067\u304d\u308b\u90e8\u5206<\/p>\n<p>UI \u30ed\u30b8\u30c3\u30af:\u00a0\u00a0CSS \u3060\u3051\u3067\u306f\u5b9f\u88c5\u3067\u304d\u306a\u3044\u90e8\u5206\uff08\uff1d\u8907\u96d1\u306a\u8996\u899a\u52b9\u679c, UI \u72b6\u614b\u7ba1\u7406, &#8230;\uff09<\/p>\n<p>\u6211\u51b3\u5b9a\u5c06\u5176\u62bd\u8c61\u4e3a\u4e24\u4e2a\u6982\u5ff5\u6765\u8003\u8651\uff08\u8bf7\u6ce8\u610f\uff0c\u8fd9\u4e24\u4e2a\u6982\u5ff5\u90fd\u662f\u4e3a\u4e86\u8fd9\u7bc7\u6587\u7ae0\u800c\u521b\u9020\u7684\u8bcd\u8bed\uff09\u3002<\/p>\n<p>\u6839\u636e\u5bf9\u6837\u5f0f\u548cUI\u903b\u8f91\u7684\u4e0d\u540c\u9700\u6c42\uff0cAngular\u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u53ef\u4ee5\u5206\u4e3a\u4ee5\u4e0b\u56db\u79cd\u6a21\u5f0f\u3002<\/p>\n<h1>Angular \u5e94\u7528\u5f00\u53d1\u7684\u6a21\u5f0f<\/h1>\n<h2>\u9009\u98791\uff1a\u300c\u6211\u60f3\u81ea\u5df1\u51c6\u5907\u6837\u5f0f\u300d\u300c\u6211\u4e5f\u60f3\u81ea\u5df1\u51c6\u5907UI\u903b\u8f91\u300d<\/h2>\n<p>\u8fd9\u662f\u4e00\u4e2a\u5728\u9700\u6c42\u5bf9\u8bbe\u8ba1\u8981\u6c42\u8f83\u9ad8\u7684PC\u7f51\u7ad9\u7684\u59d4\u6258\u5f00\u53d1\u548c\u81ea\u4e3b\u5f00\u53d1\u4e2d\u5e7f\u6cdb\u5e94\u7528\u7684\u6a21\u5f0f\u3002<\/p>\n<p>Angular\u901a\u8fc7CSS\u5c01\u88c5\u4f7f\u5f97\u6211\u4eec\u6446\u8131\u4e86\u5197\u957f\u7684CSS\u7f16\u7801\u89c4\u8303\uff0c\u76f8\u5bf9\u5bb9\u6613\u5730\u81ea\u884c\u5b9e\u73b0\u6837\u5f0f\uff0c\u5e76\u4e14\u53ea\u8981\u4e0d\u6d89\u53ca\u590d\u6742\u7684\u591a\u6307\u89e6\u63a7\u7b49\u8f93\u5165\u4e8b\u4ef6\uff0c\u81ea\u884c\u5b9e\u73b0UI\u903b\u8f91\u4e5f\u51e0\u4e4e\u6ca1\u6709\u4ec0\u4e48\u56f0\u96be\u3002\u56e0\u6b64\uff0c\u8bb8\u591a\u4eba\u9009\u62e9\u91c7\u7528\u8fd9\u79cd\u6a21\u5f0f\u6765\u786e\u8ba4Angular\u7684\u8868\u73b0\u529b\u3002<\/p>\n<p>\u7136\u800c\uff0c\u81ea\u884c\u5b9e\u73b0\u590d\u6742\u7684UI\u903b\u8f91\u5f80\u5f80\u662f\u767d\u8d39\u529b\u6c14\uff0c\u5bb9\u6613\u6210\u4e3a\u91cd\u590d\u9020\u8f6e\u5b50\uff0c\u5e76\u4e14\u5bb9\u6613\u6ecb\u751f\u9519\u8bef\u3002\u5f53\u9700\u8981\u4e00\u5b9a\u7a0b\u5ea6\u7684\u590d\u6742UI\u903b\u8f91\u65f6\uff0c\u6700\u597d\u91c7\u7528\u540e\u9762\u63d0\u5230\u7684\u6a21\u5f0f4\uff0c\u4ee5\u4fbf\u66f4\u8f7b\u677e\u5730\u6784\u5efaUI\u3002<\/p>\n<h2>\u9009\u98791: &#8220;\u6211\u60f3\u4f9d\u8d56\u5e93\u6765\u5904\u7406\u6837\u5f0f\uff0c\u4f46\u662f\u6211\u60f3\u81ea\u5df1\u51c6\u5907UI\u903b\u8f91\u3002&#8221;<\/h2>\n<p>\u5728PC\u7f51\u7ad9\/\u79fb\u52a8\u7f51\u7ad9\u4e2d\uff0c\u5e94\u7528\u903b\u8f91\u6bd4\u8bbe\u8ba1\u66f4\u91cd\u8981\u3002\u6211\u8ba4\u4e3a\u5728\u5546\u4e1a\u5e94\u7528\u5f00\u53d1\u4e2d\uff0c\u4e3b\u8981\u4f7f\u7528\u8fd9\u79cd\u6a21\u5f0f\u3002<\/p>\n<p>\u4f7f\u7528Angular\u65f6\uff0c\u6839\u636e\u4e0a\u8ff0\u7b2c\u4e00\u79cd\u60c5\u51b5\u7684\u539f\u56e0\uff0c\u6211\u4f1a\u60f3\u8981\u5c1d\u8bd5\u7528\u5168\u65b0\u7684\u65b9\u5f0f\u7f16\u5199\u6240\u6709\u7684\u6837\u5f0f\uff0c\u4f46\u662f\u5982\u679c\u5bf9\u6837\u5f0f\u6ca1\u6709\u7279\u522b\u7684\u6267\u7740\uff0c\u90a3\u4e48\u4f7f\u7528CSS\u6846\u67b6\u662f\u660e\u667a\u7684\u9009\u62e9\u3002\u5bf9\u4e8e\u5bf9CSS\u611f\u5230\u56f0\u60d1\u7684\u4eba\u6765\u8bf4\uff0c\u6211\u8ba4\u4e3a\u6682\u65f6\u505c\u6b62\u7f16\u5199\u6837\u5f0f\uff0c\u5e76\u5c1d\u8bd5\u4f7f\u7528CSS\u6846\u67b6\u53ef\u80fd\u662f\u4e2a\u597d\u4e3b\u610f\u3002<\/p>\n<p>\u542c\u5230CSS\u6846\u67b6\uff0c\u4f60\u53ef\u80fd\u4f1a\u60f3\u5230Bootstrap\uff0c\u4f46\u73b0\u5728\u6709\u5f88\u591a\u5176\u4ed6\u9009\u62e9\u3002\u56e0\u6b64\uff0c\u5728Qiita\u4e0a\u6709\u5f88\u591a\u63a8\u8350\uff0c\u8bf7\u52a1\u5fc5\u53bb\u67e5\u770b\u3002<\/p>\n<h2>\u9009\u98791\uff1a\u6a21\u5f0f3\uff1a\u201c\u6211\u60f3\u4f9d\u8d56\u5e93\u6765\u8bbe\u7f6e\u6837\u5f0f\u201d\uff0c\u201c\u6211\u4e5f\u60f3\u4f9d\u8d56\u5e93\u6765\u5904\u7406UI\u903b\u8f91\u201d\u3002<\/h2>\n<p>\u8fd9\u662f\u5728\u5f00\u53d1\u79fb\u52a8\u7f51\u7ad9\u6216 Cordova \u5e94\u7528\u7a0b\u5e8f\u65f6\uff0c\u5982\u679c\u9700\u8981\u652f\u6301\u79fb\u52a8\u8bbe\u5907\u7279\u6709\u7684\u64cd\u4f5c\uff08\u4f8b\u5982\u6ed1\u52a8\u3001\u634f\u653e\u3001\u591a\u70b9\u89e6\u63a7\u7b49\uff09\uff0c\u9700\u8981\u9009\u62e9\u7684\u60c5\u51b5\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3b3837434c4406c80b11\/23-0.png\" alt=\"\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8 2016-12-21 22.56.16.png\" \/><\/div>\n<p>\u5982\u540c angular.io \u7684\u9996\u9875\u4e0a\u6240\u5199\u7684 &#8220;One framework. Mobile &amp; desktop.&#8221;\uff0cAngular \u4e5f\u88ab\u8bbe\u8ba1\u7528\u4e8e\u79fb\u52a8\u7f51\u7ad9\u7684\u4f7f\u7528\u3002<\/p>\n<p>\u7136\u800c\uff0c\u6ed1\u52a8\u4e8b\u4ef6\u548c\u591a\u70b9\u89e6\u63a7\u4e8b\u4ef6\u5728\u672c\u8d28\u4e0a\u662f\u590d\u6742\u7684\uff0c\u5373\u4f7f\u5229\u7528 Angular \u7684\u80fd\u529b\u4e5f\u5f88\u96be\u81ea\u884c\u8fdb\u884c\u5b9e\u73b0\u3002\u4f8b\u5982\uff0c\u8981\u5b9e\u73b0\u4e00\u4e2a\u6b63\u5e38\u7684\u8f6e\u64ad\u56fe\u6216\u4fa7\u6ed1\u83dc\u5355\uff0c\u9700\u8981\u8003\u8651\u5230\u9608\u503c\u548c\u6ed1\u52a8\u52a0\u901f\u5ea6\u7b49\u56e0\u7d20\u6765\u8fdb\u884c\u5b9e\u73b0\u3002<\/p>\n<p>\u6b64\u5916\uff0c\u5728\u79fb\u52a8\u6d4f\u89c8\u5668\u4e0a\u5b9e\u73b060fps\u7684\u52a8\u753b\u5c31\u9700\u8981\u4e00\u4e9b\u9a9a\u64cd\u4f5c\u3002<\/p>\n<p>\u5728\u5f00\u53d1\u8fd9\u6837\u7684\u79fb\u52a8\u7f51\u7ad9\u65f6\uff0c\u91c7\u7528\u6a21\u5f0f1\u6216\u6a21\u5f0f2\u662f\u4e0d\u660e\u667a\u7684\u3002\uff08\u5982\u679c\u5e0c\u671b\u5904\u7406\u4e00\u5b9a\u590d\u6742\u7684PC\u7f51\u7ad9UI\u903b\u8f91\uff0c\u4f7f\u7528\u6a21\u5f0f1\u6216\u6a21\u5f0f2\u662f\u4e0d\u660e\u667a\u7684\uff09<\/p>\n<hr \/>\n<p>\u5728\u6a21\u5f0f3\u4e2d\uff0c\u5c06\u4f7f\u7528UI\u6846\u67b6\u800c\u4e0d\u662fCSS\u6846\u67b6\u3002CSS\u6846\u67b6\u53ea\u63d0\u4f9b\u6837\u5f0f\uff0c\u800cUI\u6846\u67b6\u63d0\u4f9b\u6837\u5f0f\u548cUI\u903b\u8f91\u3002\u4e5f\u5c31\u662f\u8bf4\uff0c\u4f7f\u7528UI\u6846\u67b6\u53ef\u4ee5\u7701\u53bb\u81ea\u5df1\u5b9e\u73b0\u6837\u5f0f\u548cUI\u903b\u8f91\u7684\u9ebb\u70e6\uff0c\u66f4\u52a0\u8f7b\u677e\u3002<\/p>\n<p>\u7136\u800c\uff0c\u4e0eCSS\u6846\u67b6\u4e0d\u540c\u7684\u662f\uff0cUI\u6846\u67b6\u7684\u9009\u62e9\u975e\u5e38\u6709\u9650\u3002\u8fd9\u662f\u56e0\u4e3a\u63d0\u4f9b\u7279\u5b9a\u4e8e\u67d0\u4e2aJS\u6846\u67b6\u7684UI\u903b\u8f91\u4f1a\u5bfc\u81f4\u7ef4\u62a4\u6210\u672c\u975e\u5e38\u9ad8\uff0c\u76f8\u6bd4CSS\u6846\u67b6\u800c\u8a00\u3002<\/p>\n<p>\u5728Angular\u4f7f\u7528\u7684UI\u6846\u67b6\u4e2d\uff0c\u6709\u51e0\u4e2a\u77e5\u540d\u7684\u9009\u9879\u3002\u9996\u5148\u662f\u9002\u7528\u4e8ePC\u548c\u79fb\u52a8\u8bbe\u5907\u7684Material Design for Angular 2\uff1b\u53e6\u5916\uff0c\u8fd8\u6709\u9002\u7528\u4e8ePC\u548c\u79fb\u52a8\u8bbe\u5907\u4f46\u66f4\u503e\u5411\u4e8e\u79fb\u52a8\u8bbe\u5907\u7684Ionic2\u3002\u6b64\u5916\u8fd8\u6709\u6211\u81ea\u5df1\u7684\u4f5c\u54c1Onsen UI 2\u3002<\/p>\n<p>\u8bf7\u52a1\u5fc5\u9605\u8bfb\u7b2c8\u5929\u7684@rdlabo\u7684\u6587\u7ae0\uff0c\u5176\u4e2d\u8be6\u7ec6\u6574\u7406\u4e86\u6709\u5173\u8fd9\u65b9\u9762\u7684\u5185\u5bb9\u3002<\/p>\n<p>\u3010\u521d\u5b66\u8005\u6307\u5357\u3011\u4e00\u8d77\u770b\u770b\u4e0eAngular2\u4e00\u8d77\u4f7f\u7528\u7684\u77e5\u540d\u7b2c\u4e09\u65b9\u5e93 &#8211; Tech Tech \u95a2\u897f\uff5c\u79d1\u6280\u79d1\u6280\u95a2\u897f<\/p>\n<h2>\u9009\u9879\u4e00\uff1a\u6a21\u5f0f4\uff1a\u201c\u6211\u60f3\u81ea\u5df1\u51c6\u5907\u98ce\u683c\u201d\uff0c\u201c\u6211\u60f3\u4f9d\u8d56\u5e93\u6765\u5904\u7406\u7528\u6237\u754c\u9762\u903b\u8f91\u201d\u3002<\/h2>\n<p>\u8fd9\u79cd\u6a21\u5f0f\u88ab\u7528\u4e8e\u5f53\u6211\u4eec\u4e0d\u60f3\u53d7\u5230\u5e93\u7684\u9650\u5236\u65f6\uff0c\u4f46\u662f\u81ea\u5df1\u5b9e\u73b0 UI \u903b\u8f91\u592a\u96be\u7684\u60c5\u51b5\u4e0b\u5e0c\u671b\u501f\u52a9\u5e93\u7684\u597d\u5904\u7684\u60c5\u51b5\u4e0b\u3002<\/p>\n<p>\u7136\u800c\uff0c\u76ee\u524d\u5c1a\u672a\u5b58\u5728&#8221;\u53ea\u63d0\u4f9bUI\u903b\u8f91\u800c\u4e0d\u63d0\u4f9b\u6837\u5f0f&#8221;\u7684\u5e93\uff0c\u56e0\u6b64\u5728\u8fd9\u79cd\u60c5\u51b5\u4e0b\uff0c\u9700\u8981\u4fee\u6539\u548c\u8986\u76d6UI\u6846\u67b6\u4e2d\u9644\u5e26\u7684\u6837\u5f0f\u3002<\/p>\n<p>\u5728\u8fd9\u79cd\u60c5\u51b5\u4e0b\uff0c\u5982\u679c\u8fdb\u884c\u8d85\u51faUI\u6846\u67b6\u63a5\u53d7\u8303\u56f4\u7684\u4fee\u6539\uff0c\u5c06\u4f1a\u9047\u5230\u56f0\u6270\u4e8e\u6837\u5f0f\u65b9\u9762\u7684\u9519\u8bef\uff0c\u4f46\u4e0e\u65b9\u68481\u76f8\u6bd4\uff0c\u6700\u7ec8\u7684\u5de5\u65f6\u4f1a\u51cf\u5c11\u3002<\/p>\n<h1>\u603b\u7ed3\u5230\u8fd9\u91cc<\/h1>\n<p>\u6211\u5011\u5df2\u7d93\u4ecb\u7d39\u4e86Angular\u61c9\u7528\u958b\u767c\u7684\u56db\u7a2e\u6a21\u5f0f\u3002<br \/>\n\u5982\u679c\u60a8\u6b63\u5728\u9078\u64c7\u6a21\u5f0f1\uff0c\u8acb\u52d9\u5fc5\u8003\u616e\u9078\u64c7\u6a21\u5f0f2\u81f3\u6a21\u5f0f4\u3002<\/p>\n<p>\u4ee5\u4e0b\u662f\u9644\u5e26\u8bdd\u9898\u3002<\/p>\n<h1>\u6211\u4f7f\u7528\u4e86Angular2-OnsenUI\u6765\u521b\u5efa\u3002<\/h1>\n<p>\u7531\u4e8e\u4eca\u5e74\u4e0b\u534a\u5e74\u6211\u521b\u7acb\u4e86\u4e00\u4e2a\u540d\u4e3aangular2-onsenui\u7684\u8f6f\u4ef6\u5305\uff0c\u6240\u4ee5\u6211\u5c06\u7b80\u5355\u4ecb\u7ecd\u4e00\u4e0b\u5b83\u7684\u89c4\u683c\uff08\u8865\u5145\u8bf4\u660e\uff1a\u5f00\u53d1\u4e3b\u8981\u7531@anatoo\u5b8c\u6210\uff09\u3002<\/p>\n<p>angular2-onsenui\u662f\u4e00\u4e2a\u7528\u4e8e\u5728Angular\u4e2d\u4f7f\u7528Onsen UI 2\u7684\u5305\u3002\u5b83\u662f\u4e3a\u6a21\u5f0f3\u548c4\u7684\u4f7f\u7528\u800c\u8bbe\u8ba1\u7684\u3002<\/p>\n<h2>\u53ef\u4ee5\u5236\u4f5c\u7684\u4e1c\u897f (Koreareru mono)<\/h2>\n<p>\u6211\u53ef\u4ee5\u5236\u4f5c\u8fd9\u6837\u7684\u4e1c\u897f\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3b3837434c4406c80b11\/46-0.png\" alt=\"img_3_trimmed.png\" \/><\/div>\n<h2>\u8fd0\u7528\u65b9\u5f0f<\/h2>\n<p>\u53ef\u4ee5\u4f7f\u7528npm\u6765\u5b89\u88c5onsenui\u548cangular2-onsenui\uff0c\u5e76\u52a0\u8f7dOnsenModule\u4ee5\u4f9b\u4f7f\u7528\u3002\u5173\u4e8e\u8be6\u7ec6\u6b65\u9aa4\uff0c\u53ef\u4ee5\u53c2\u8003@rdlabo\u7684Angular CLI\u4f7f\u7528\u65b9\u6cd5\u7684\u603b\u7ed3\u3002<\/p>\n<p>\u653e\u5f03\u4f7f\u7528monaca-cli\u5427\uff01\u4e3a\u4e86\u4f7f\u7528OnsenUI2\uff0c\u6700\u597d\u4eceangular-cli\u5f00\u59cb\u7684\u539f\u56e0\u548c\u4f7f\u7528\u65b9\u6cd5 &#8211; Tech Tech Kansai\uff5c\u30c6\u30af\u30c6\u30af\u5173\u897f<br \/>\nhttp:\/\/tec-kansai.tech\/technology-2584.php<\/p>\n<p>\u6587\u6863\u5b58\u653e\u5728\u4e0b\u9762\u7684\u4f4d\u7f6e\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Angular 2 \u5411\u3051 Onsen UI 2 \u30ac\u30a4\u30c9 &#8211; Onsen UI \u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">Angular 2 \u5411\u3051 Onsen UI 2 \u30c9\u30ad\u30e5\u30e1\u30f3\u30c8 &#8211; Onsen UI \u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af<\/ul>\n<h2>\u53ef\u4f7f\u7528\u7684\u7ec4\u4ef6<\/h2>\n<p>\u52a0\u8f7d OnsenModule \u540e\uff0c\u60a8\u53ef\u4ee5\u4f7f\u7528\u4ee5\u4e0b\u9009\u62e9\u5668\u6765\u4f7f\u7528 Onsen UI 2 \u7684\u7ec4\u4ef6\u3002<\/p>\n<p>\u203b \u8fd9\u662f 1.0.0-rc.3 \u7248\u672c\u7684\u89c4\u8303\u3002<\/p>\n<div>\n<div class=\"post-table\">\u7a2e\u5225\u30bb\u30ec\u30af\u30bf\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u30af\u30e9\u30b9 *1\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u30d5\u30a1\u30af\u30c8\u30ea\u30af\u30e9\u30b9 *2\u30da\u30fc\u30b8\u30de\u30cd\u30fc\u30b8\u30e3<code>ons-navigator<\/code><code>OnsNavigator<\/code>\u306a\u3057<\/p>\n<p>\u30da\u30fc\u30b8\u30de\u30cd\u30fc\u30b8\u30e3<code>ons-splitter<\/code>\u306a\u3057 *3\u306a\u3057\u30da\u30fc\u30b8\u30de\u30cd\u30fc\u30b8\u30e3<code>ons-splitter-side<\/code><code>OnsSplitterSide<\/code>\u306a\u3057\u30da\u30fc\u30b8\u30de\u30cd\u30fc\u30b8\u30e3<code>ons-splitter-content<\/code><code>OnsSplitterContent<\/code>\u306a\u3057<\/p>\n<p>\u30da\u30fc\u30b8\u30de\u30cd\u30fc\u30b8\u30e3<code>ons-tabbar<\/code>\u306a\u3057\u306a\u3057\u30da\u30fc\u30b8\u30de\u30cd\u30fc\u30b8\u30e3<code>ons-tab<\/code><code>OnsTab<\/code>\u306a\u3057<\/p>\n<p>\u30da\u30fc\u30b8<code>ons-page<\/code>\u306a\u3057\u306a\u3057\u30da\u30fc\u30b8<code>ons-toolbar<\/code>\u306a\u3057\u306a\u3057\u30da\u30fc\u30b8<code>ons-toolbar-button<\/code>\u306a\u3057\u306a\u3057\u30da\u30fc\u30b8<code>ons-back-button<\/code>\u306a\u3057\u306a\u3057\u30da\u30fc\u30b8<code>ons-bottom-toolbar<\/code>\u306a\u3057\u306a\u3057<\/p>\n<p>\u30e2\u30fc\u30c0\u30eb\u30a6\u30a3\u30f3\u30c9\u30a6<code>ons-modal<\/code>\u306a\u3057<code>ModalFactory<\/code><\/p>\n<p>\u30c0\u30a4\u30a2\u30ed\u30b0<code>ons-alert-dialog<\/code>\u306a\u3057<code>AlertDialogFactory<\/code>\u30c0\u30a4\u30a2\u30ed\u30b0<code>ons-dialog<\/code>\u306a\u3057<code>DialogFactory<\/code>\u30c0\u30a4\u30a2\u30ed\u30b0<code>ons-popover<\/code>\u306a\u3057<code>PopoverFactory<\/code><\/p>\n<p>\u30a2\u30a4\u30b3\u30f3<code>ons-icon<\/code>\u306a\u3057\u306a\u3057<\/p>\n<p>\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-pull-hook<\/code><code>OnsPullHook<\/code>\u306a\u3057<\/p>\n<p>\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-carousel<\/code>\u306a\u3057\u306a\u3057\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-carousel-item<\/code>\u306a\u3057\u306a\u3057<\/p>\n<p>\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-list<\/code>\u306a\u3057\u306a\u3057\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-list-header<\/code>\u306a\u3057\u306a\u3057\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-list-item<\/code>\u306a\u3057\u306a\u3057\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-lazy-repeat<\/code><code>OnsLazyRepeat<\/code>\u306a\u3057<\/p>\n<p>\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-input<\/code><code>OnsInput<\/code>\u306a\u3057<\/p>\n<p>\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-button<\/code>\u306a\u3057<br \/>\n\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-range<\/code><code>OnsRange<\/code>\u306a\u3057\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-switch<\/code><code>OnsSwitch<\/code>\u306a\u3057<\/p>\n<p>\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-fab<\/code>\u306a\u3057\u306a\u3057\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-speed-dial<\/code>\u306a\u3057\u306a\u3057\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-speed-dial-item<\/code>\u306a\u3057\u306a\u3057<\/p>\n<p>\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-progress-bar<\/code>\u306a\u3057\u306a\u3057\u30a6\u30a3\u30b8\u30a7\u30c3\u30c8<code>ons-progress-circular<\/code>\u306a\u3057\u306a\u3057<\/p>\n<p>\u6761\u4ef6\u5206\u5c90<code>ons-if<\/code>\u306a\u3057\u306a\u3057<\/p>\n<p>\u30b0\u30ea\u30c3\u30c9\u30ec\u30a4\u30a2\u30a6\u30c8<code>ons-row<\/code>\u306a\u3057\u306a\u3057\u30b0\u30ea\u30c3\u30c9\u30ec\u30a4\u30a2\u30a6\u30c8<code>ons-col<\/code>\u306a\u3057\u306a\u3057<\/p>\n<p>\u30bf\u30c3\u30c1\u30a4\u30d9\u30f3\u30c8<code>ons-gesture-detector<\/code>\u306a\u3057\u306a\u3057<\/p>\n<p>\u8996\u899a\u52b9\u679c<code>ons-ripple<\/code>\u306a\u3057\u306a\u3057<\/div>\n<\/div>\n<p>\u4e25\u683c\u6765\u8bf4\uff0c\u6bcf\u4e2a\u7ec4\u4ef6\u7c7b\u5b9e\u9645\u4e0a\u662f\u4f7f\u7528 @Directive \u800c\u4e0d\u662f @Component \u8fdb\u884c\u5b9e\u73b0\u7684\u3002\u56e0\u4e3a Onsen UI \u5728 template \u4e0a\u5e76\u6ca1\u6709\u4f7f\u7528 @Component\uff0c\u800c\u662f\u4f7f\u7528\u4e86 Custom Elements V1 \u7684 connectedCallback \u548c attributeChangedCallback \u94a9\u5b50\u6765\u8fdb\u884c\u6a21\u677f\u7684\u9644\u52a0\uff0c\u6240\u4ee5\u5e76\u4e0d\u9700\u8981\u4f7f\u7528 @Component\u3002<\/p>\n<p>\u6211\u4eec\u4e3a\u9700\u8981\u52a8\u6001\u751f\u6210\u7684\u7ec4\u4ef6\uff0c\u5982\u6a21\u6001\u7a97\u53e3\u548c\u5bf9\u8bdd\u6846\uff0c\u63d0\u4f9b\u4e86\u7ec4\u4ef6\u5de5\u5382\u3002<\/p>\n<p>\u9488\u5bf9\u4e0d\u9700\u8981\u8f93\u5165\u3001\u8f93\u51fa\u6216\u65b9\u6cd5\u7684\u7ec4\u4ef6\uff0c\u6211\u4eec\u6ca1\u6709\u51c6\u5907\u7ec4\u4ef6\u7c7b\u3002<\/p>\n<h2>\u4f7f\u7528\u65b9\u6cd51\uff1a\u5c0f\u90e8\u4ef6<\/h2>\n<p>\u5728\u6a21\u677f\u4e2d\u53ea\u9700\u7b80\u5355\u5730\u653e\u7f6e push \u7b49\u6807\u7b7e\u5373\u53ef\u4f7f\u7528\u5c0f\u90e8\u4ef6\u7ec4\u4ef6\uff0c\u65e0\u9700\u7279\u522b\u8003\u8651\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">Component<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">OnsenModule<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">NgModule<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">CUSTOM_ELEMENTS_SCHEMA<\/span>\r\n<span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">angular2-onsenui<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">platformBrowserDynamic<\/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\r\n<span class=\"kr\">declare<\/span> <span class=\"kd\">var<\/span> <span class=\"nx\">alert<\/span><span class=\"p\">:<\/span> <span class=\"nb\">Function<\/span><span class=\"p\">;<\/span>\r\n\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\">app<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"s2\">`\r\n    &lt;ons-button (click)=\"onClick()\"&gt;push&lt;\/ons-button&gt;\r\n    `<\/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>\r\n  <span class=\"kd\">constructor<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"p\">}<\/span>\r\n\r\n  <span class=\"nx\">onClick<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">alert<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">Clicked!<\/span><span class=\"dl\">'<\/span><span class=\"p\">);<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">NgModule<\/span><span class=\"p\">({<\/span>\r\n  <span class=\"na\">imports<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">OnsenModule<\/span><span class=\"p\">],<\/span>\r\n  <span class=\"na\">declarations<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">AppComponent<\/span><span class=\"p\">],<\/span>\r\n  <span class=\"na\">bootstrap<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">AppComponent<\/span><span class=\"p\">],<\/span>\r\n  <span class=\"na\">schemas<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">CUSTOM_ELEMENTS_SCHEMA<\/span><span class=\"p\">]<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"kd\">class<\/span> <span class=\"nx\">AppModule<\/span> <span class=\"p\">{<\/span> <span class=\"p\">}<\/span>\r\n\r\n<span class=\"nx\">platformBrowserDynamic<\/span><span class=\"p\">().<\/span><span class=\"nx\">bootstrapModule<\/span><span class=\"p\">(<\/span><span class=\"nx\">AppModule<\/span><span class=\"p\">);<\/span>\r\n<\/code><\/pre>\n<p>\u52a8\u4f5c\u793a\u4f8b\uff08Plunker\uff09\uff1a<br \/>\nhttps:\/\/plnkr.co\/edit\/rySiuIg8JF3bOn33Gn0S<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3b3837434c4406c80b11\/63-0.png\" alt=\"\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8 2016-12-22 2.22.28.png\" \/><\/div>\n<h2>\u65b9\u6cd5\u4e8c\uff1a\u9875\u9762\u7ba1\u7406\u5668<\/h2>\n<p>\u4f7f\u7528\u9875\u9762\u7ba1\u7406\u5668\u7ec4\u4ef6\u7684\u65b9\u6cd5\u6709\u70b9\u590d\u6742\u3002<br \/>\n\u4ee5\u4e0b\u662f\u4f7f\u7528 ons-navigator \u7684\u793a\u4f8b\u3002<\/p>\n<p>\u9996\u5148\uff0c\u5728\u4ee5\u4e0b\u7684\u4ee3\u7801\u4e2d\uff0c\u6211\u4eec\u901a\u8fc7\u5728 DefaultPageComponent \u7c7b\u548c Page2Component \u7c7b\u4e2d\u5b9a\u4e49\u201c\u9875\u9762\u201d\uff0c\u5e76\u5c06\u5176\u63d0\u4f9b\u7ed9 ons-navigator \u5143\u7d20\u7684\u8f93\u5165\uff0c\u6765\u663e\u793a\u9875\u9762\u3002<br \/>\n\u7531\u4e8e\u6bcf\u4e2a\u9875\u9762\uff08\u5b9e\u9645\u4e0a\u662f\u7ec4\u4ef6\uff09\u9700\u8981\u52a8\u6001\u751f\u6210\uff0c\u56e0\u6b64\u6211\u4eec\u5728 NgModule \u7684 entryComponents \u4e2d\u9884\u5148\u6ce8\u518c\u4e86 DefaultPageComponent \u7c7b\u548c Page2Component \u7c7b\u3002<br \/>\n\u9875\u9762\u7ec4\u4ef6\u7684\u9009\u62e9\u5668\u4e5f\u8fdb\u884c\u4e86\u5c5e\u6027\u6307\u5b9a\uff0c\u6bd4\u5982 ons-page[page2] \u6216 ons-page[default]\uff0c\u8fd9\u662f\u56e0\u4e3a\u4f7f\u7528 ons-page \u65f6\uff0c\u5f53\u5b9a\u4e49\u591a\u4e2a\u9875\u9762\u65f6\u9009\u62e9\u5668\u4f1a\u53d1\u751f\u51b2\u7a81\u5bfc\u81f4\u9519\u8bef\u3002<\/p>\n<p>\u5728\u6bcf\u4e2a\u9875\u9762\u4e2d\uff0c\u901a\u8fc7\u8c03\u7528\u4f7f\u7528DI\u83b7\u53d6\u7684OnsNavigator\u5b9e\u4f8b\u7684\u65b9\u6cd5\u6765\u5b9e\u73b0\u9875\u9762\u7684\u8df3\u8f6c\u3002\u6b63\u5982\u8fd9\u6bb5\u4ee3\u7801 this._navigator.element.popPage(); \u6240\u793a\uff0c\u8fd9\u4e2a\u793a\u4f8b\u76f4\u63a5\u8c03\u7528\u4e86\u4e0eDOM\u5143\u7d20\u76f8\u5173\u8054\u7684\u65b9\u6cd5\uff0c\u8fd9\u662f\u7531\u4e8e\u5176\u5185\u90e8\u4f7f\u7528\u4e86Custom Elements V1\u89c4\u8303\u5bfc\u81f4\u7684\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">Component<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">ViewChild<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">Params<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">OnsNavigator<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">OnsenModule<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">NgModule<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">CUSTOM_ELEMENTS_SCHEMA<\/span>\r\n<span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">angular2-onsenui<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">platformBrowserDynamic<\/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\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\">ons-page[page2]<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"s2\">`\r\n    &lt;ons-toolbar&gt;\r\n      &lt;div class=\"left\"&gt;&lt;ons-back-button&gt;Back&lt;\/ons-back-button&gt;&lt;\/div&gt;\r\n      &lt;div class=\"center\"&gt;Page2&lt;\/div&gt;\r\n    &lt;\/ons-toolbar&gt;\r\n    &lt;div class=\"content\"&gt;\r\n      &lt;div style=\"text-align: center; margin: 10px\"&gt;\r\n        &lt;ons-button (click)=\"push()\"&gt;push&lt;\/ons-button&gt;\r\n        &lt;ons-button id=\"pop\" (click)=\"pop()\"&gt;pop&lt;\/ons-button&gt;\r\n      &lt;\/div&gt;\r\n    &lt;\/div&gt;\r\n  `<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">Page2Component<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"kd\">constructor<\/span><span class=\"p\">(<\/span><span class=\"k\">private<\/span> <span class=\"nx\">_navigator<\/span><span class=\"p\">:<\/span> <span class=\"nx\">OnsNavigator<\/span><span class=\"p\">,<\/span> <span class=\"k\">private<\/span> <span class=\"nx\">_params<\/span><span class=\"p\">:<\/span> <span class=\"nx\">Params<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"p\">}<\/span>\r\n\r\n  <span class=\"nx\">push<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">_navigator<\/span><span class=\"p\">.<\/span><span class=\"nx\">element<\/span><span class=\"p\">.<\/span><span class=\"nx\">pushPage<\/span><span class=\"p\">(<\/span><span class=\"nx\">Page2Component<\/span><span class=\"p\">,<\/span> <span class=\"p\">{<\/span><span class=\"na\">animation<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">slide<\/span><span class=\"dl\">'<\/span><span class=\"p\">);<\/span>\r\n  <span class=\"p\">}<\/span>\r\n\r\n  <span class=\"nx\">pop<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">_navigator<\/span><span class=\"p\">.<\/span><span class=\"nx\">element<\/span><span class=\"p\">.<\/span><span class=\"nx\">popPage<\/span><span class=\"p\">();<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\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\">ons-page[default]<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"s2\">`\r\n    &lt;ons-toolbar&gt;\r\n      &lt;div class=\"center\"&gt;Page&lt;\/div&gt;\r\n    &lt;\/ons-toolbar&gt;\r\n    &lt;div class=\"content\"&gt;\r\n      &lt;div style=\"text-align: center; margin: 10px\"&gt;\r\n        &lt;ons-button id=\"push\" (click)=\"push(navi)\"&gt;push&lt;\/ons-button&gt;\r\n      &lt;\/div&gt;\r\n    &lt;\/div&gt;\r\n  `<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"kd\">class<\/span> <span class=\"nx\">DefaultPageComponent<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"kd\">constructor<\/span><span class=\"p\">(<\/span><span class=\"k\">private<\/span> <span class=\"nx\">_navigator<\/span><span class=\"p\">:<\/span> <span class=\"nx\">OnsNavigator<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"p\">}<\/span>\r\n\r\n  <span class=\"nx\">push<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">_navigator<\/span><span class=\"p\">.<\/span><span class=\"nx\">element<\/span><span class=\"p\">.<\/span><span class=\"nx\">pushPage<\/span><span class=\"p\">(<\/span><span class=\"nx\">Page2Component<\/span><span class=\"p\">);<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\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\">app<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"s2\">`\r\n  &lt;ons-navigator animation=\"slide\" [page]=\"defaultPage\"&gt;&lt;\/ons-navigator&gt;\r\n  `<\/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>\r\n  <span class=\"nx\">defaultPage<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">DefaultPageComponent<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">NgModule<\/span><span class=\"p\">({<\/span>\r\n  <span class=\"na\">imports<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">OnsenModule<\/span><span class=\"p\">],<\/span>\r\n  <span class=\"na\">declarations<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">AppComponent<\/span><span class=\"p\">,<\/span> <span class=\"nx\">DefaultPageComponent<\/span><span class=\"p\">,<\/span> <span class=\"nx\">Page2Component<\/span><span class=\"p\">],<\/span>\r\n  <span class=\"na\">entryComponents<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">DefaultPageComponent<\/span><span class=\"p\">,<\/span> <span class=\"nx\">Page2Component<\/span><span class=\"p\">],<\/span>\r\n  <span class=\"na\">bootstrap<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">AppComponent<\/span><span class=\"p\">],<\/span>\r\n  <span class=\"na\">schemas<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">CUSTOM_ELEMENTS_SCHEMA<\/span><span class=\"p\">]<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"kd\">class<\/span> <span class=\"nx\">AppModule<\/span> <span class=\"p\">{<\/span> <span class=\"p\">}<\/span>\r\n\r\n<span class=\"nx\">platformBrowserDynamic<\/span><span class=\"p\">().<\/span><span class=\"nx\">bootstrapModule<\/span><span class=\"p\">(<\/span><span class=\"nx\">AppModule<\/span><span class=\"p\">);<\/span>\r\n<\/code><\/pre>\n<p>\u52a8\u4f5c\u793a\u4f8b\uff08Plunker\uff09\uff1a<br \/>\n\u8bf7\u67e5\u770b\u4ee5\u4e0b\u94fe\u63a5\uff1ahttps:\/\/plnkr.co\/edit\/MoLFcdTRTbD7C7v8A69C<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3b3837434c4406c80b11\/70-0.gif\" alt=\"3466c1cfa0fed7622006cc862e6ec9fa.gif\" \/><\/div>\n<h2>\u9009\u98793\uff1a\u6a21\u6001\u7a97\u53e3\u3001\u5bf9\u8bdd\u6846\u7684\u7528\u6cd5\u3002<\/h2>\n<p>\u5e94\u8be5\u4f7f\u7528\u7ec4\u4ef6\u5de5\u5382\u52a8\u6001\u751f\u6210\u548c\u4f7f\u7528\u7c7b\u4f3c\u6a21\u6001\u7a97\u53e3\u548c\u5bf9\u8bdd\u6846\u7684\u7ec4\u4ef6\uff0c\u8fd9\u4e9b\u7ec4\u4ef6\u4e0d\u5e94\u8be5\u5c5e\u4e8e\u5e94\u7528\u7a0b\u5e8f\u7684\u7ec4\u4ef6\u6811\u5185\u3002<\/p>\n<p>\u5728\u4e0b\u9762\u7684\u4f8b\u5b50\u4e2d\uff0c\u6211\u4eec\u52a8\u6001\u751f\u6210\u5bf9\u8bdd\u6846\uff0c\u5e76\u901a\u8fc7\u70b9\u51fb\u6309\u94ae\u6765\u89e6\u53d1\u663e\u793a\u5bf9\u8bdd\u6846\u3002<\/p>\n<p>\u8981\u8fdb\u884c\u52a8\u6001\u751f\u6210\u5bf9\u8bdd\u6846\uff0c\u9996\u5148\u9700\u8981\u5728\u6a21\u677f\u4e2d\u5b9a\u4e49\u4e00\u4e2a\u6ca1\u6709\u9009\u62e9\u5668\u7684 MyDialogComponent \u7c7b\uff0c\u5b83\u5177\u6709 ons-dialog \u5143\u7d20\u3002\u7136\u540e\u5c06\u8be5\u7c7b\u6ce8\u518c\u5230NgModule\u7684entryComponents\u4e2d\u3002\u63a5\u4e0b\u6765\uff0c\u6267\u884c\u7531DI\u83b7\u53d6\u7684DialogFactory\u5b9e\u4f8b\u7684createDialog\u65b9\u6cd5\u3002\u7136\u540e\uff0c\u5c31\u4f1a\u5f02\u6b65\u8fd4\u56de\u751f\u6210\u7684ons-dialog\u5143\u7d20\uff08\u4ee5\u53ca\u7528\u4e8e\u9500\u6bc1\u5bf9\u8bdd\u6846\u7ec4\u4ef6\u7684\u51fd\u6570\uff09\u3002\u6700\u540e\uff0c\u53ea\u9700\u6267\u884cthis._dialog.show(); \u5373\u53ef\u663e\u793a\u5bf9\u8bdd\u6846\u3002<\/p>\n<p>angular2-onsenui\u63d0\u4f9b\u4e86DialogFactory\u4e4b\u5916\u7684AlertDialogFactory\uff0cPopoverFactory\u548cModalFactory\u3002<\/p>\n<p>\u4f7f\u7528\u7ec4\u4ef6\u5de5\u5382\u65f6\uff0c\u8bf7\u5728ngOnDestroy\u65f6\u4e0d\u8981\u5fd8\u8bb0\u4f7f\u7528this._destroyDialog()\u7b49\u65b9\u6cd5\u6765\u9500\u6bc1\u7ec4\u4ef6\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">Component<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">DialogFactory<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">AfterViewInit<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">OnInit<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">OnDestroy<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">Params<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">OnsenModule<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">NgModule<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">CUSTOM_ELEMENTS_SCHEMA<\/span>\r\n<span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">angular2-onsenui<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">platformBrowserDynamic<\/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\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span><span class=\"p\">({<\/span>\r\n  <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"s2\">`\r\n    &lt;ons-dialog animation=\"default\" cancelable #dialog&gt;\r\n      &lt;div class=\"dialog-mask\"&gt;&lt;\/div&gt;\r\n      &lt;div class=\"dialog\"&gt;\r\n        &lt;div class=\"dialog-container\" style=\"height: 200px;\"&gt;\r\n          &lt;ons-page&gt;\r\n            &lt;ons-toolbar&gt;\r\n              &lt;div class=\"center\"&gt;Name&lt;\/div&gt;\r\n            &lt;\/ons-toolbar&gt;\r\n            &lt;div class=\"content\"&gt;\r\n              &lt;div style=\"text-align: center\"&gt;\r\n                &lt;p&gt;{{message}}&lt;\/p&gt;\r\n                &lt;br&gt;\r\n                &lt;ons-button id=\"close\" (click)=\"dialog.hide()\"&gt;Close&lt;\/ons-button&gt;\r\n              &lt;\/div&gt;\r\n            &lt;\/div&gt;\r\n          &lt;\/ons-page&gt;\r\n        &lt;\/div&gt;\r\n      &lt;\/div&gt;\r\n    &lt;\/ons-dialog&gt;\r\n  `<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"kd\">class<\/span> <span class=\"nx\">MyDialogComponent<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">message<\/span> <span class=\"o\">=<\/span> <span class=\"dl\">''<\/span><span class=\"p\">;<\/span>\r\n\r\n  <span class=\"kd\">constructor<\/span><span class=\"p\">(<\/span><span class=\"nx\">params<\/span><span class=\"p\">:<\/span> <span class=\"nx\">Params<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">message<\/span> <span class=\"o\">=<\/span> <span class=\"o\">&lt;<\/span><span class=\"kr\">string<\/span><span class=\"o\">&gt;<\/span><span class=\"nx\">params<\/span><span class=\"p\">.<\/span><span class=\"nx\">at<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">message<\/span><span class=\"dl\">'<\/span><span class=\"p\">);<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\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\">app<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"s2\">`\r\n  &lt;ons-page class=\"page\"&gt;\r\n    &lt;ons-toolbar&gt;\r\n      &lt;div class=\"center\"&gt;Dialog&lt;\/div&gt;\r\n    &lt;\/ons-toolbar&gt;\r\n    &lt;div class=\"content\"&gt;\r\n      &lt;div style=\"text-align: center;\"&gt;\r\n        &lt;br&gt;\r\n        &lt;ons-button id=\"open\" (click)=\"show()\"&gt;Open&lt;\/ons-button&gt;\r\n      &lt;\/div&gt;\r\n    &lt;\/div&gt;\r\n  &lt;\/ons-page&gt;\r\n  `<\/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=\"k\">implements<\/span> <span class=\"nx\">OnInit<\/span><span class=\"p\">,<\/span> <span class=\"nx\">OnDestroy<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"k\">private<\/span> <span class=\"nx\">_dialog<\/span><span class=\"p\">:<\/span> <span class=\"kr\">any<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"k\">private<\/span> <span class=\"nx\">_destroyDialog<\/span><span class=\"p\">:<\/span> <span class=\"nb\">Function<\/span><span class=\"p\">;<\/span>\r\n\r\n  <span class=\"kd\">constructor<\/span><span class=\"p\">(<\/span><span class=\"k\">private<\/span> <span class=\"nx\">_dialogFactory<\/span><span class=\"p\">:<\/span> <span class=\"nx\">DialogFactory<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"p\">}<\/span>\r\n\r\n  <span class=\"nx\">ngOnInit<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">_dialogFactory<\/span>\r\n      <span class=\"p\">.<\/span><span class=\"nx\">createDialog<\/span><span class=\"p\">(<\/span><span class=\"nx\">MyDialogComponent<\/span><span class=\"p\">,<\/span> <span class=\"p\">{<\/span><span class=\"na\">message<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">This is just an example.<\/span><span class=\"dl\">'<\/span><span class=\"p\">})<\/span>\r\n      <span class=\"p\">.<\/span><span class=\"nx\">then<\/span><span class=\"p\">(({<\/span><span class=\"nx\">dialog<\/span><span class=\"p\">,<\/span> <span class=\"nx\">destroy<\/span><span class=\"p\">})<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">_dialog<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">dialog<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">_destroyDialog<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">destroy<\/span><span class=\"p\">;<\/span>\r\n      <span class=\"p\">});<\/span>\r\n  <span class=\"p\">}<\/span>\r\n\r\n  <span class=\"nx\">show<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">if<\/span> <span class=\"p\">(<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">_dialog<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">_dialog<\/span><span class=\"p\">.<\/span><span class=\"nx\">show<\/span><span class=\"p\">();<\/span>\r\n    <span class=\"p\">}<\/span>\r\n  <span class=\"p\">}<\/span>\r\n\r\n  <span class=\"nx\">ngOnDestroy<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">_destroyDialog<\/span><span class=\"p\">();<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">NgModule<\/span><span class=\"p\">({<\/span>\r\n  <span class=\"na\">imports<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">OnsenModule<\/span><span class=\"p\">],<\/span>\r\n  <span class=\"na\">declarations<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">AppComponent<\/span><span class=\"p\">,<\/span> <span class=\"nx\">MyDialogComponent<\/span><span class=\"p\">],<\/span>\r\n  <span class=\"na\">bootstrap<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">AppComponent<\/span><span class=\"p\">],<\/span>\r\n  <span class=\"na\">entryComponents<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">MyDialogComponent<\/span><span class=\"p\">],<\/span>\r\n  <span class=\"na\">schemas<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">CUSTOM_ELEMENTS_SCHEMA<\/span><span class=\"p\">]<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"kd\">class<\/span> <span class=\"nx\">AppModule<\/span> <span class=\"p\">{<\/span> <span class=\"p\">}<\/span>\r\n\r\n<span class=\"nx\">platformBrowserDynamic<\/span><span class=\"p\">().<\/span><span class=\"nx\">bootstrapModule<\/span><span class=\"p\">(<\/span><span class=\"nx\">AppModule<\/span><span class=\"p\">);<\/span>\r\n<\/code><\/pre>\n<p>\u52a8\u4f5c\u793a\u4f8b\uff08Plunker\uff09\uff1a<br \/>\nhttps:\/\/plnkr.co\/edit\/ZAu5BstNGklPIYliVBtt<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3b3837434c4406c80b11\/79-0.gif\" alt=\"75b785084c8d0956734ce599c7546b91.gif\" \/><\/div>\n<h1>\u603b\u7ed3<\/h1>\n<p>\u6211\u4ecb\u7ecd\u4e864\u79cdAngular\u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u6a21\u5f0f\uff0c\u5176\u4e2dUI\u7ec4\u4ef6\u5206\u4e3a\u6837\u5f0f\u548cUI\u903b\u8f91\u4e24\u90e8\u5206\u8fdb\u884c\u5b9a\u4e49\u3002<\/p>\n<p>\u6b64\u5916\uff0c\u6211\u7b80\u8981\u4ecb\u7ecd\u4e86\u6211\u7684\u4f5c\u54c1 angular2-onsenui \u7684\u89c4\u683c\u548c\u4f7f\u7528\u65b9\u6cd5\u3002<\/p>\n<h1>\u6211\u60f3\u8ac7\u8ac7\u5225\u7684\u8a71\u984c\u3002<\/h1>\n<p>\u7531\u65bc\u7d93\u5e38\u88ab\u554f\u53ca\u95dc\u65bc Onsen UI \u7684\u958b\u767c\u76ee\u6a19\uff0c\u6240\u4ee5\u6211\u5011\u63d0\u524d\u56de\u7b54\u4e00\u4e0b\uff0cOnsen UI \u7684\u958b\u767c\u4e26\u4e0d\u662f\u70ba\u4e86\u76f4\u63a5\u5e36\u4f86\u5229\u76ca\uff08\u6216\u8005\u8aaa\uff0c\u6211\u8a8d\u70ba\u9019\u6a23\u7684\u958b\u6e90\u8edf\u9ad4\u90fd\u662f\u5982\u6b64\uff09\u3002<br \/>\n\u6700\u521d\u662f\u56e0\u70ba\u6211\u5011\u5167\u90e8\u81ea\u5bb6\u670d\u52d9\u7684\u9700\u8981\uff0c\u6240\u4ee5\u6211\u5011\u6c7a\u5b9a\u5c07\u5176\u516c\u958b\u70ba\u958b\u6e90\u8edf\u9ad4\u3002<\/p>\n<p>\u5173\u4e8e\u8be6\u7ec6\u7ecf\u8fc7\uff0c\u8bf7\u67e5\u770bOnsen UI\u9879\u76ee\u8d1f\u8d23\u4eba@massie\u6240\u5199\u7684\u6587\u7ae0\u3002<\/p>\n<p>Onsen UI\u7684\u8d77\u6e90\uff1a\u4e9a\u9521\u5c14\u535a\u5ba2<br \/>\nhttp:\/\/blog.asial.co.jp\/1490<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u672c\u6587\u662f2016\u5e74Angular Advent Calendar\u7b2c21\u5929\u7684\u6587\u7ae0\u3002 \u6211\u5728\u4eca\u5e74\u7684\u4e0b\u534a\u5e74\u5f00\u53d1\u4e86\u4e00\u4e2a\u540d\u4e3a [&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-39559","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>Angular \u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u7684\u5206\u7c7b\u548c\u521b\u5efa Angular UI \u6846\u67b6\u7684\u6545\u4e8b - 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\/angular-\u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u7684\u5206\u7c7b\u548c\u521b\u5efa-angular-ui-\u6846\u67b6\u7684\u6545\u4e8b\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Angular \u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u7684\u5206\u7c7b\u548c\u521b\u5efa Angular UI \u6846\u67b6\u7684\u6545\u4e8b\" \/>\n<meta property=\"og:description\" content=\"\u672c\u6587\u662f2016\u5e74Angular Advent Calendar\u7b2c21\u5929\u7684\u6587\u7ae0\u3002 \u6211\u5728\u4eca\u5e74\u7684\u4e0b\u534a\u5e74\u5f00\u53d1\u4e86\u4e00\u4e2a\u540d\u4e3a [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/angular-\u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u7684\u5206\u7c7b\u548c\u521b\u5efa-angular-ui-\u6846\u67b6\u7684\u6545\u4e8b\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-09-26T10:50:28+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-30T05:04:29+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3b3837434c4406c80b11\/23-0.png\" \/>\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\/angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b\/\",\"name\":\"Angular \u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u7684\u5206\u7c7b\u548c\u521b\u5efa Angular UI \u6846\u67b6\u7684\u6545\u4e8b - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-09-26T10:50:28+00:00\",\"dateModified\":\"2024-04-30T05:04:29+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/f044a4b7fa4ee2701702942002419ca6\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Angular \u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u7684\u5206\u7c7b\u548c\u521b\u5efa Angular UI \u6846\u67b6\u7684\u6545\u4e8b\"}]},{\"@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\/angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Angular \u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u7684\u5206\u7c7b\u548c\u521b\u5efa Angular UI \u6846\u67b6\u7684\u6545\u4e8b - 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\/angular-\u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u7684\u5206\u7c7b\u548c\u521b\u5efa-angular-ui-\u6846\u67b6\u7684\u6545\u4e8b\/","og_locale":"zh_CN","og_type":"article","og_title":"Angular \u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u7684\u5206\u7c7b\u548c\u521b\u5efa Angular UI \u6846\u67b6\u7684\u6545\u4e8b","og_description":"\u672c\u6587\u662f2016\u5e74Angular Advent Calendar\u7b2c21\u5929\u7684\u6587\u7ae0\u3002 \u6211\u5728\u4eca\u5e74\u7684\u4e0b\u534a\u5e74\u5f00\u53d1\u4e86\u4e00\u4e2a\u540d\u4e3a [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/angular-\u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u7684\u5206\u7c7b\u548c\u521b\u5efa-angular-ui-\u6846\u67b6\u7684\u6545\u4e8b\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-09-26T10:50:28+00:00","article_modified_time":"2024-04-30T05:04:29+00:00","og_image":[{"url":"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3b3837434c4406c80b11\/23-0.png"}],"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\/angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b\/","name":"Angular \u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u7684\u5206\u7c7b\u548c\u521b\u5efa Angular UI \u6846\u67b6\u7684\u6545\u4e8b - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-09-26T10:50:28+00:00","dateModified":"2024-04-30T05:04:29+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/f044a4b7fa4ee2701702942002419ca6"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"Angular \u5e94\u7528\u7a0b\u5e8f\u5f00\u53d1\u7684\u5206\u7c7b\u548c\u521b\u5efa Angular UI \u6846\u67b6\u7684\u6545\u4e8b"}]},{"@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\/angular-%e5%ba%94%e7%94%a8%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e5%88%86%e7%b1%bb%e5%92%8c%e5%88%9b%e5%bb%ba-angular-ui-%e6%a1%86%e6%9e%b6%e7%9a%84%e6%95%85%e4%ba%8b\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39559","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=39559"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39559\/revisions"}],"predecessor-version":[{"id":92076,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39559\/revisions\/92076"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=39559"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=39559"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=39559"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}