{"id":39623,"date":"2023-01-28T23:28:56","date_gmt":"2023-08-11T11:31:40","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88\/"},"modified":"2024-04-29T11:58:51","modified_gmt":"2024-04-29T03:58:51","slug":"vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88\/","title":{"rendered":"Vue.js\/Blazor\/Angular\u7684\u8bed\u6cd5\u6bd4\u8f83\u793a\u4f8b\u96c6\u5408"},"content":{"rendered":"<p>\u9488\u5bf9\u5177\u6709\u4e00\u5b9a\u7a0b\u5ea6\u7684Vue.js\/Blazor\/Angular\u8bed\u6cd5\u7684\u65b9\u6cd5\uff0c\u6211\u4eec\u603b\u7ed3\u4e86\u5b9e\u73b0\u7c7b\u4f3c\u529f\u80fd\u7684\u65b9\u5f0f\u3002\u6e90\u4ee3\u7801\u8bf7\u53c2\u8003VueVsBlazor\u3002<\/p>\n<p>\u987a\u4fbf\u63d0\u4e00\u4e0b\uff0c\u5728Vue.js\u4e2d\u6211\u4eec\u91c7\u7528\u4e86TypeScript\u3002<\/p>\n<h1>\u52a8\u4f5c\u793a\u4f8b\u9875\u9762<\/h1>\n<p>Vue.js \u793a\u4f8b<br \/>\nBlazor \u793a\u4f8b<br \/>\nAngular \u793a\u4f8b<\/p>\n<h1>\u8bed\u6cd5\u6bd4\u8f83<\/h1>\n<p>\u8fd9\u91cc\u7684\u6837\u672c\u5168\u90e8\u8868\u793a\u4e3a\u8def\u7531\u5668\u4e0a\u7684\u4e00\u9875\u3002<br \/>\n\u6211\u4eec\u5c06\u6309\u7167\u57fa\u7840\u8def\u7531\u5668\u5b9e\u73b0\u7684\u793a\u4f8b\u9010\u4e2a\u6bd4\u8f83\u3002<\/p>\n<h2>0. \u6700\u5c0f\u7684\u7ec4\u4ef6<\/h2>\n<p>\u7ec4\u4ef6\u7684\u5185\u5bb9\u53ef\u4ee5\u4ec5\u7531\u7b80\u5355\u7684 HTML \u5b9e\u73b0\u3002<\/p>\n<h3>Vue.js (a JavaScript framework) can be rephrased in Chinese as &#8220;Vue.js\uff08\u4e00\u4e2aJavaScript\u6846\u67b6\uff09&#8221;.<\/h3>\n<p>\u9700\u8981\u5c06\u5176\u5c01\u88c5\u5728template\u6807\u7b7e\u4e2d\u3002<br \/>\n\u53ea\u9700\u8981\u4f7f\u7528\u4e00\u4e2a\u5757\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Hello Vue.js!<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u84dd\u5149\u6807\u5fd7<\/h3>\n<p>\u6c92\u6709\u7279\u5225\u9700\u8981\u8003\u616e\u7684\u4e8b\u9805\u3002<br \/>\n\u6703\u6839\u64da\u6240\u8f38\u5165\u7684\u5167\u5bb9\u52d5\u614b\u751f\u6210 HTML\u3002<br \/>\n\u901a\u5e38\u60c5\u6cc1\u4e0b\uff0c\u7121\u6cd5\u4f7f\u7528 script \u6a19\u7c64\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Hello Blazor!<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<\/code><\/pre>\n<h2>\u89d2<\/h2>\n<p>Note: &#8220;Angulae&#8221; does not have a direct translation in Chinese. In Chinese, the word &#8220;\u89d2&#8221; is a noun that can refer to &#8220;angle&#8221; or &#8220;corner&#8221; in a geometric sense. If you are looking for a suitable translation for a different context, such as a specific term related to anatomy or a different meaning, please provide more information for a more accurate translation.<\/p>\n<p>\u5728TypeScript\u4e2d\u5c06html\u4f5c\u4e3a\u6a21\u677f\u63d2\u5165\u3002<br \/>\n\u5206\u522b\u4fdd\u5b58html\u548ccss\u6587\u4ef6\u4f3c\u4e4e\u662f\u4e3b\u6d41\uff0c\u4f46\u5728\u8fd9\u91cc\u5c06\u5b83\u4eec\u89c6\u4e3a\u540c\u4e00\u4e2a\u6587\u4ef6\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h1&gt;Hello Angular!&lt;\/h1&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">Index<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">IndexComponent<\/span><span class=\"p\">{}<\/span>\r\n<\/code><\/pre>\n<h2>1. \u6837\u5f0f\u8868<\/h2>\n<h3>Vue.js \u53ef\u4ee5\u8fdb\u884c\u4e2d\u6587\u539f\u751f\u5316\u91cd\u8ff0\u4e3a\uff1aVue.js\uff08\u89c6\u56fe\uff09\u662f\u4e00\u4e2a\u6d41\u884c\u7684 JavaScript \u6846\u67b6\u3002<\/h3>\n<p>\u4f7f\u7528style\u6807\u7b7e\u53ef\u4ee5\u63cf\u8ff0\u6837\u5f0f\u3002<br \/>\n\u901a\u8fc7\u4f7f\u7528scoped\u5c5e\u6027\uff0c\u53ef\u4ee5\u5728\u7ec4\u4ef6\u5185\u521b\u5efa\u201c\u4f5c\u7528\u57df\u201d\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div<\/span> <span class=\"na\">id=<\/span><span class=\"s\">index<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Hello Vue.js!<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">style<\/span> <span class=\"na\">scoped<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">div<\/span><span class=\"nf\">#index<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">color<\/span><span class=\"p\">:<\/span> <span class=\"m\">#0000FF<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>Blazor<\/h3>\n<p>\u5728Blazor\u4e2d\uff0c\u6ca1\u6709\u7279\u5b9a\u7684CSS\u673a\u5236\u3002<br \/>\n\u56e0\u6b64\uff0c\u6211\u4eec\u53ea\u80fd\u5c06\u6837\u5f0f\u6807\u7b7e\u653e\u5728body\u4e2d\u3002<br \/>\n\u55ef\uff0c\u5728\u5927\u591a\u6570\u6d4f\u89c8\u5668\u4e2d\u90fd\u80fd\u6b63\u5e38\u5de5\u4f5c\u3002<br \/>\n\u81f3\u4e8e\u5728HTML\u4e0a\u662f\u597d\u8fd8\u662f\u574f\uff0c\u6211\u4e5f\u4e0d\u77e5\u9053\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/StyleBlock\"\r\n\r\n<span class=\"nt\">&lt;div<\/span> <span class=\"na\">id=<\/span><span class=\"s\">index<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Hello Blazor!<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">div<\/span><span class=\"nf\">#index<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">color<\/span><span class=\"p\">:<\/span> <span class=\"m\">#0000FF<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>Angular (\u89d2\u5ea6)<\/h3>\n<p>\u53ef\u4ee5\u5728HTML\u4e2d\u5d4c\u5165\u6837\u5f0f\u8868\u3002\u867d\u7136\u8fd9\u91cc\u6ca1\u6709\u793a\u4f8b\uff0c\u4f46\u4e5f\u53ef\u4ee5\u4ece\u5176\u4ed6\u6587\u4ef6\u4e2d\u5bfc\u5165\u6837\u5f0f\u8868\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div id=index&gt;\r\n    &lt;h1&gt;Hello Angular!&lt;\/h1&gt;\r\n&lt;\/div&gt;\r\n\r\n&lt;style&gt;\r\ndiv#index{\r\n    color: #0000FF;\r\n}\r\n&lt;\/style&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">StyleBlock<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">StyleBlockComponent<\/span><span class=\"p\">{}<\/span>\r\n<\/code><\/pre>\n<h2>2. \u5d4c\u5165\u4ee3\u7801\u5757\/\u811a\u672c<\/h2>\n<p>\u5728\u4ee3\u7801\u5757\u4e2d\u5b9a\u4e49\u7684\u53d8\u91cf\u53ef\u4ee5\u5d4c\u5165\u5230HTML\u4e2d\u3002<br \/>\n\uff08Vue.js\/Angular\u53ef\u4f7f\u7528{{hoge}}\uff08this\u59cb\u7ec8\u6dfb\u52a0\uff09\uff0cC#\u53ef\u4f7f\u7528@hoge\u8fdb\u884c\u8c03\u7528\uff09<\/p>\n<h3>Vue.js \u662f\u4e00\u4e2a\u6d41\u884c\u7684 JavaScript \u6846\u67b6\uff0c\u7528\u4e8e\u6784\u5efa\u7528\u6237\u754c\u9762\u3002<\/h3>\n<p>\u5c06\u811a\u672c\u6807\u7b7e\u5185\u7684\u5185\u5bb9\u5199\u6210(TypeScript\u7684\u60c5\u51b5\u4e0b\u9700\u8981\u6dfb\u52a0lang=ts)\u7684\u683c\u5f0f\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span><span class=\"si\">{{<\/span><span class=\"nx\">title<\/span><span class=\"si\">}}<\/span><span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ScriptBlock<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">title<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Hello Vue.js!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u5e03\u62c9\u6cfd<\/h3>\n<p>\u5728@code\u4ee3\u7801\u5757\u4e2d\u7f16\u5199\u811a\u672c\u5904\u7406\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/ScriptBlock\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>@title<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@code{\r\n    string title=\"Hello Blazor!\";\r\n}\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<p>\u7531\u4e8eTypeScript\u662f\u57fa\u7840\uff0c\u6240\u4ee5\u53ef\u80fd\u6ca1\u6709\u4ec0\u4e48\u7279\u522b\u503c\u5f97\u6ce8\u610f\u7684\u4e8b\u60c5\u3002<br \/>\n\u6211\u4eec\u5c06\u5728\u25cb\u25cb.component.ts\u7684\u7c7b\u5185\u7f16\u5199\u5904\u7406\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h1&gt;{{title}}&lt;\/h1&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">ScriptBlock<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ScriptBlockComponent<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">title<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Hello Vue.js!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>3. \u5728HTML\u4e2d\u5d4c\u5165\u6570\u5b66\u516c\u5f0f<\/h2>\n<p>\u5728HTML\u4e2d\uff0c\u53ef\u4ee5\u5d4c\u5165\u7684\u4e0d\u4ec5\u4ec5\u662f\u53d8\u91cf\uff0c\u8fd8\u53ef\u4ee5\u5d4c\u5165\u6570\u5b66\u516c\u5f0f\u3002<\/p>\n<h3>Vue.js &#8211; \u4e00\u79cd\u6d41\u884c\u7684JavaScript\u6846\u67b6\u3002<\/h3>\n<p>\u8bf7\u6ce8\u610f\u5728{{}}\u5185\u65e0\u6cd5\u5904\u7406\u5168\u5c40\u5bf9\u8c61\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>10!=<span class=\"si\">{{<\/span><span class=\"mi\">10<\/span><span class=\"o\">*<\/span><span class=\"mi\">9<\/span><span class=\"o\">*<\/span><span class=\"mi\">8<\/span><span class=\"o\">*<\/span><span class=\"mi\">7<\/span><span class=\"o\">*<\/span><span class=\"mi\">6<\/span><span class=\"o\">*<\/span><span class=\"mi\">5<\/span><span class=\"o\">*<\/span><span class=\"mi\">4<\/span><span class=\"o\">*<\/span><span class=\"mi\">3<\/span><span class=\"o\">*<\/span><span class=\"mi\">2<\/span><span class=\"o\">*<\/span><span class=\"mi\">1<\/span><span class=\"si\">}}<\/span><span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>Blazor &#8211; \u53ea\u9700\u8981\u4e00\u4e2a\u9009\u9879\uff0c\u7528\u4e2d\u6587\u8fdb\u884c\u672c\u5730\u5316\u3002<\/h3>\n<p>\u5c06@\u7684\u8f6c\u4e49\u5b57\u7b26\u5199\u4e3a@@\u6765\u8868\u793a\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/Formula\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>10!=@(10*9*8*7*6*5*4*3*2*1)<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<p>\u4e0eVue.js\u7c7b\u4f3c\uff0c\u65e0\u6cd5\u5728{{}}\u5185\u5904\u7406\u5168\u5c40\u5bf9\u8c61\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h1&gt;10!={{10*9*8*7*6*5*4*3*2*1}}&lt;\/h1&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">Formula<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">FormulaComponent<\/span><span class=\"p\">{}<\/span>\r\n<\/code><\/pre>\n<h2>4. \u751f\u547d\u5468\u671f\u65b9\u6cd5 f\u01ce)<\/h2>\n<p>Vue.js\/Blazor\/Angular\u90fd\u6709\u4e00\u4e9b\u7c7b\u4f3c\u4e8ehtml\u7684onload\/unonload\u7684\u751f\u547d\u5468\u671f\u65b9\u6cd5\uff0c\u5b83\u4eec\u4f1a\u5728\u7ec4\u4ef6\u7684\u72b6\u6001\u53d1\u751f\u53d8\u5316\u65f6\u88ab\u89e6\u53d1\u3002<\/p>\n<div>\n<div class=\"post-table\">\u9805\u76eeVue.jsBlazorAngular\u521d\u671f\u5316\u524dbeforeCreate\u2015constructor\u203b3\u521d\u671f\u5316\u5f8ccreatedOnInitialized<br \/>\nOnInitializedAsync\u2015\u30ec\u30f3\u30c0\u30ea\u30f3\u30b0\u524dbeforeMountOnParametersSet<br \/>\nOnParametersSetAsync\u2015\u30ec\u30f3\u30c0\u30ea\u30f3\u30b0\u5f8cmountedOnAfterRender<br \/>\nOnAfterRenderAsync\u203b1ngOnInit\u5909\u66f4\u524dbeforeUpdate\u2015ngDoCheck<br \/>\nngAfterViewInit\u5909\u66f4\u5f8cupdatedOnAfterRender<br \/>\nOnAfterRenderAsync\u203b1ngAfterViewChecked\u30a2\u30af\u30c6\u30a3\u30d6\u5316\u6642activated\u2015\u2015\u975e\u30a2\u30af\u30c6\u30a3\u30d6\u5316\u6642deactivated\u2015\u2015\u7834\u68c4\u524dbeforeUpdate\u2015\u2015\u7834\u68c4\u6642beforeDestroyDispose\u203b2ngOnDestroy<\/div>\n<\/div>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u203b1: firstRender\u5f15\u6570\u3067\u521d\u56de\u304b\u3069\u3046\u304b\u5224\u5225\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u203b2: \u30da\u30fc\u30b8\u30ea\u30ed\u30fc\u30c9\u6642\u306b\u306f\u52d5\u4f5c\u3057\u306a\u3044\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u203b3: \u30b5\u30fc\u30d3\u30b9\u306e\u767b\u9332\u306b\u3082\u4f7f\u7528\u3055\u308c\u308b\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u203b4: Angular\u306f\u52b9\u679c\u304c\u308f\u304b\u308a\u306b\u304f\u3044\u3082\u306e\u304c\u591a\u3044\u306e\u3067\u308f\u304b\u308b\u3082\u306e\u3060\u3051\u3002<\/ul>\n<p>Vue.js\u7684\u751f\u547d\u5468\u671f<br \/>\nBlazor\u7684\u751f\u547d\u5468\u671f<br \/>\nAngular\u7684\u751f\u547d\u5468\u671f<\/p>\n<p>\u6211\u89c9\u5f97\u521d\u59cb\u5904\u7406\u5927\u6982\u5728\u6e32\u67d3\u540e\u5c31\u80fd\u591f\u5b8c\u6210\u3002<br \/>\n\u9700\u8981\u6ce8\u610f\u7684\u662f\uff0cBlazor\u5728\u9875\u9762\u66f4\u65b0\u65f6\u4e0d\u4f1a\u6267\u884c\u6790\u6784\u51fd\u6570\u3002<br \/>\n\uff08\u5728\u8fd9\u79cd\u60c5\u51b5\u4e0b\uff0c\u76ee\u524d\u4f3c\u4e4e\u53ea\u80fd\u4f7f\u7528js\u7684unonload\u6765\u5904\u7406\uff1f\uff09<\/p>\n<h3>Vue.js\u7684\u4e2d\u6587\u7248\u672c<\/h3>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span><span class=\"si\">{{<\/span><span class=\"nx\">title<\/span><span class=\"si\">}}<\/span><span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">LifeCycle<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">title<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Hello Vue.js!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"k\">async<\/span> <span class=\"nx\">mounted<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"k\">await<\/span> <span class=\"k\">new<\/span> <span class=\"nb\">Promise<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"o\">=&gt;<\/span><span class=\"nx\">setTimeout<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"p\">,<\/span><span class=\"mi\">5000<\/span><span class=\"p\">));<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">title<\/span><span class=\"o\">+=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\"> 5s passed!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<\/code><\/pre>\n<h3>\u5e03\u62c9\u7d22<\/h3>\n<pre class=\"post-pre\"><code>@page \"\/LifeCycle\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>@title<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@code{\r\n    string title=\"Hello Blazor!\";\r\n\r\n    protected override async Task OnAfterRenderAsync(bool firstRender){\r\n        if(!firstRender) return;\r\n        await Task.Delay(5000);\r\n        title+=\" 5s passed!\";\r\n        StateHasChanged();\r\n    }\r\n}\r\n\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h1&gt;{{title}}&lt;\/h1&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">OnInit<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@angular\/core<\/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=\"s2\">LifeCycle<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">LifeCycleComponent<\/span> <span class=\"k\">implements<\/span> <span class=\"nx\">OnInit<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">title<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Hello Angular!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"k\">async<\/span> <span class=\"nx\">ngOnInit<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"k\">await<\/span> <span class=\"k\">new<\/span> <span class=\"nb\">Promise<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"o\">=&gt;<\/span><span class=\"nx\">setTimeout<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"p\">,<\/span><span class=\"mi\">5000<\/span><span class=\"p\">));<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">title<\/span><span class=\"o\">+=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\"> 5s passed!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>5. \u6587\u6863\u5bf9\u8c61\u6a21\u578b\uff08DOM\uff09\u5e94\u7528\u7a0b\u5e8f\u63a5\u53e3<\/h2>\n<p>\u5728\u9009\u62e9\u4f7f\u7528JavaScript\/TypeScript\u7684\u6846\u67b6\u4e2d\uff0c\u53ef\u4ee5\u76f4\u63a5\u4f7f\u7528\u4e0e\u6d4f\u89c8\u5668\u76f8\u5173\u7684DOM API\u3002<\/p>\n<h3>Vue.js is a framework for building user interfaces, which is popular for its simplicity and ease of use.<\/h3>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Alert<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">UseDOMAPI<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"k\">async<\/span> <span class=\"nx\">mounted<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"kd\">var<\/span> <span class=\"nx\">title<\/span><span class=\"o\">=<\/span><span class=\"nb\">document<\/span><span class=\"p\">.<\/span><span class=\"nx\">title<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"nx\">alert<\/span><span class=\"p\">(<\/span><span class=\"nx\">title<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u5e03\u96f7\u6cfd\u5c14<\/h3>\n<p>\u5728Blazor\u4e2d\uff0c\u5982\u679c\u4e0d\u4f9d\u9760JavaScript\uff0c\u662f\u4e0d\u53ef\u80fd\u64cd\u4f5cDOM API\u7684\uff0c\u56e0\u6b64\u9700\u8981\u8c03\u7528JavaScript\u7684\u65b9\u6cd5\u3002<\/p>\n<p>\u4e3a\u4e86\u4f7f\u7528JavaScript\uff0c\u9700\u8981\u6ce8\u5165IJSRuntime\u5e76\u8c03\u7528IJSRuntime.InvoveAsync\u548cIJSRuntime.InvokeVoidAsync\u65b9\u6cd5\u3002<\/p>\n<p>\u7531\u4e8e\u4e0d\u80fd\u76f4\u63a5\u8bbf\u95ee\u5c5e\u6027\uff0c\u56e0\u6b64\u9700\u8981\u4f7f\u7528 eval \u6216\u51c6\u5907\u4e00\u4e2a JavaScript \u6587\u4ef6\u5e76\u5c06\u5176\u4f5c\u4e3a\u51fd\u6570\u8c03\u7528\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/UseDOMAPI\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Alert<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@inject IJSRuntime js\r\n\r\n@code{\r\n    protected override async Task OnAfterRenderAsync(bool firstRender){\r\n        if(!firstRender) return;\r\n        var title=await js.InvokeAsync<span class=\"nt\">&lt;string&gt;<\/span>(\"eval\",\"document.title\");\r\n        await js.InvokeVoidAsync(\"alert\",title);\r\n    }\r\n}\r\n\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h1&gt;Alert&lt;\/h1&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">OnInit<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@angular\/core<\/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=\"s2\">UseDOMAPI<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">UseDOMAPIComponent<\/span> <span class=\"k\">implements<\/span> <span class=\"nx\">OnInit<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">ngOnInit<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"kd\">var<\/span> <span class=\"nx\">title<\/span><span class=\"o\">=<\/span><span class=\"nb\">document<\/span><span class=\"p\">.<\/span><span class=\"nx\">title<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"nx\">alert<\/span><span class=\"p\">(<\/span><span class=\"nx\">title<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>6. \u53cc\u5411\u7ed1\u5b9a<\/h2>\n<p>\u5728Vue.js\/Blazor\/Angular\u4e2d\uff0c\u4e0d\u76f4\u63a5\u64cd\u4f5cdocument.element.value\uff0c\u800c\u662f\u901a\u8fc7\u7ed1\u5b9a\uff08\u540c\u6b65\uff09\u53d8\u91cf\u548c\u5143\u7d20\u503c\u6765\u5b9e\u73b0\u3002<\/p>\n<h3>Vue.js\u662f\u4e00\u79cd\u6d41\u884c\u7684JavaScript\u6846\u67b6\u3002<\/h3>\n<p>\u4f7f\u7528v-model\u5c5e\u6027\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span><span class=\"si\">{{<\/span><span class=\"nx\">title<\/span><span class=\"si\">}}<\/span><span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n    <span class=\"nt\">&lt;input<\/span> <span class=\"na\">v-model=<\/span><span class=\"s\">\"title\"<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">BindingInput<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">title<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Hello Vue.js!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u4e2d\u56fd\u51fa\u4ea7\u7684\u52a8\u753b\u7535\u5f71\u300a\u75af\u72c2\u52a8\u7269\u57ce\u300b\u5728\u5168\u7403\u53d6\u5f97\u4e86\u5de8\u5927\u6210\u529f\u3002<\/h3>\n<p>\u5982\u679c\u9700\u8981\u5b9e\u65f6\u66f4\u65b0\u6587\u672c\uff0c\u8bf7\u4f7f\u7528@bind-value \/ @bind-value: event\u5c5e\u6027\uff08\u53c2\u89c1\u7b2c20\u9879\uff09\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/BindingInput\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>@title<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n    <span class=\"nt\">&lt;input<\/span> <span class=\"err\">@<\/span><span class=\"na\">bind=<\/span><span class=\"s\">\"title\"<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@code{\r\n    string title=\"Hello Blazor!\";\r\n}\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<p>\u4f7f\u7528[(ngModel)]\u5c5e\u6027\u3002<br \/>\n[]\u8868\u793a\u901a\u8fc7\u811a\u672c\u5904\u7406\u7684\u503c\u88ab\u4fee\u6539\uff0c<br \/>\n()\u8868\u793a\u53ef\u4ee5\u901a\u8fc7\u4eba\u4e3a\u64cd\u4f5c\u6765\u6539\u53d8\u503c\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h1&gt;{{title}}&lt;\/h1&gt;\r\n    &lt;input [(ngModel)]=\"title\"&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">BindingInput<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">BindingInputComponent<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">title<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Hello Angular!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>7. \u5355\u5411\u7ed1\u5b9a<\/h2>\n<p>\u60a8\u8fd8\u53ef\u4ee5\u901a\u8fc7\u66f4\u6539\u53d8\u91cf\u6765\u5355\u5411\u66f4\u65b0document.element.value\u3002<\/p>\n<h3>Vue.js \u662f\u4e00\u4e2a\u7528\u4e8e\u6784\u5efa\u7528\u6237\u754c\u9762\u7684\u5f00\u6e90JavaScript\u6846\u67b6\u3002<\/h3>\n<p>\u5c06v-bind:value\u4f5c\u4e3a\u5c5e\u6027\u6307\u5b9a\u3002<br \/>\nv-bind: \u8868\u793a\u503c\u4f1a\u6839\u636e\u811a\u672c\u5904\u7406\u800c\u53d8\u5316\u3002<br \/>\nv-bind: \u53ef\u4ee5\u7f29\u5199\u4e3a: \uff0c\u56e0\u6b64\u53ef\u4ee5\u5199\u4e3a:value\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span><span class=\"si\">{{<\/span><span class=\"nx\">title<\/span><span class=\"si\">}}<\/span><span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n    <span class=\"nt\">&lt;input<\/span> <span class=\"na\">:value=<\/span><span class=\"s\">\"title\"<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">BindingInputOneWay<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">title<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Hello Vue.js!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"k\">async<\/span> <span class=\"nx\">mounted<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"k\">for<\/span><span class=\"p\">(;;){<\/span>\r\n            <span class=\"k\">await<\/span> <span class=\"k\">new<\/span> <span class=\"nb\">Promise<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"o\">=&gt;<\/span><span class=\"nx\">setTimeout<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"p\">,<\/span><span class=\"mi\">2000<\/span><span class=\"p\">));<\/span>\r\n            <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">title<\/span><span class=\"o\">+=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">&gt;<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"p\">}<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u5e03\u62c9\u7d22\uff08Blazor\uff09<\/h3>\n<p>\u53ef\u4ee5\u76f4\u63a5\u5c06value\u5206\u914d\u7ed9\u53d8\u91cf\u4f5c\u4e3a@\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/BindingInputOneWay\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>@title<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n    <span class=\"nt\">&lt;input<\/span> <span class=\"na\">value=<\/span><span class=\"s\">@title<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@code{\r\n    string title=\"Hello Blazor!\";\r\n\r\n    protected override async Task OnAfterRenderAsync(bool firstRender){\r\n        if(!firstRender) return;\r\n        for(;;){\r\n            await Task.Delay(2000);\r\n            title+=\"&gt;\";\r\n            StateHasChanged();\r\n        }\r\n    }\r\n}\r\n<\/code><\/pre>\n<h3>Angular (\u89d2\u5ea6)<\/h3>\n<p>\u4f7f\u7528[ngModel]\u5c5e\u6027\u3002<br \/>\n\u4e0e\u524d\u4e00\u9879[(ngModel)]\u4e0d\u540c\u7684\u662f\uff0c\u53bb\u9664\u4e86()(\u4eba\u5de5\u4fee\u6539)\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h1&gt;{{title}}&lt;\/h1&gt;\r\n    &lt;input [ngModel]=\"title\"&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">OnInit<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@angular\/core<\/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=\"s2\">BindingInputOneWay<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">BindingInputOneWayComponent<\/span> <span class=\"k\">implements<\/span> <span class=\"nx\">OnInit<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">title<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Hello Angular!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"k\">async<\/span> <span class=\"nx\">ngOnInit<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"k\">for<\/span><span class=\"p\">(;;){<\/span>\r\n            <span class=\"k\">await<\/span> <span class=\"k\">new<\/span> <span class=\"nb\">Promise<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"o\">=&gt;<\/span><span class=\"nx\">setTimeout<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"p\">,<\/span><span class=\"mi\">2000<\/span><span class=\"p\">));<\/span>\r\n            <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">title<\/span><span class=\"o\">+=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">&gt;<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"p\">}<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>8. \u4e8b\u4ef6\u5904\u7406\u5668<\/h2>\n<p>\u7531\u4e8e\u4e8b\u4ef6\u5904\u7406\u7a0b\u5e8f\u7684\u8868\u8fbe\u65b9\u5f0f\u5404\u4e0d\u76f8\u540c\uff0c\u6240\u4ee5\u5728\u5e38\u89c4\u7684HTML\u4e2d\u4e5f\u4f1a\u540c\u65f6\u63d0\u53ca\u3002<br \/>\n\u5728Vue.js\/Blazor\u4e2d\uff0c\u53ea\u9700\u6307\u5b9a\u65b9\u6cd5\u540d\u5373\u53ef\uff0c\u65e0\u9700\u4f7f\u7528\u62ec\u53f7\u8868\u793a\u65b9\u6cd5\u8c03\u7528\u3002<\/p>\n<h3>HTML \u662f\u4e00\u79cd\u7528\u4e8e\u521b\u5efa\u7f51\u9875\u7684\u6807\u51c6\u6807\u8bb0\u8bed\u8a00\u3002<\/h3>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;html&gt;<\/span>\r\n<span class=\"nt\">&lt;body&gt;<\/span>\r\n    <span class=\"nt\">&lt;button<\/span> <span class=\"na\">onclick=<\/span><span class=\"s\">\"openDialog()\"<\/span><span class=\"nt\">&gt;<\/span>Click Me!<span class=\"nt\">&lt;\/button&gt;<\/span>\r\n\r\n    <span class=\"nt\">&lt;script&gt;<\/span>\r\n        <span class=\"kd\">var<\/span> <span class=\"nx\">title<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Hello HTML!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n        <span class=\"kd\">function<\/span> <span class=\"nx\">openDialog<\/span><span class=\"p\">(){<\/span>\r\n            <span class=\"nx\">alert<\/span><span class=\"p\">(<\/span><span class=\"nx\">title<\/span><span class=\"p\">);<\/span>\r\n        <span class=\"p\">}<\/span>\r\n    <span class=\"nt\">&lt;\/script&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<h3>Vue.js\u662f\u4e00\u79cd\u73b0\u4ee3\u7684JavaScript\u6846\u67b6\uff0c\u7528\u4e8e\u6784\u5efa\u7528\u6237\u754c\u9762\u3002<\/h3>\n<p>\u4f7f\u7528v-on:click\u5c5e\u6027\u4ee3\u66ffonclick\u5c5e\u6027\u3002<br \/>\nv-on: \u8868\u793a\u53ef\u4ee5\u901a\u8fc7\u4eba\u4e3a\u64cd\u4f5c\u6765\u6539\u53d8\u503c\u3002<br \/>\nv-on: \u4e5f\u53ef\u4ee5\u7528@\u8868\u793a\uff0c\u6240\u4ee5\u53ef\u4ee5\u5199\u6210@click\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;button<\/span> <span class=\"err\">@<\/span><span class=\"na\">click=<\/span><span class=\"s\">\"openDialog\"<\/span><span class=\"nt\">&gt;<\/span>Click Me!<span class=\"nt\">&lt;\/button&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">EventHandler<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">title<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Hello Vue.js!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"nx\">openDialog<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"nx\">alert<\/span><span class=\"p\">(<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">title<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u84dd\u7ef3<\/h3>\n<p>\u4e00\u822c\u60c5\u51b5\u4e0b\uff0c\u7ed9\u5e38\u89c4\u4e8b\u4ef6\u540d\u79f0\u52a0\u4e0a@\u7b26\u53f7\u5c31\u6210\u4e3a\u4e86\u4e8b\u4ef6\u5c5e\u6027\u3002<br \/>\n\u4e5f\u5c31\u662f\u8bf4\uff0c\u5728\u8fd9\u4e2a\u4f8b\u5b50\u4e2d\uff0c\u662f@onclick\u5c5e\u6027\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/EventHandler\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;button<\/span> <span class=\"err\">@<\/span><span class=\"na\">onclick=<\/span><span class=\"s\">\"openDialog\"<\/span><span class=\"nt\">&gt;<\/span>Click Me!<span class=\"nt\">&lt;\/button&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@inject IJSRuntime js\r\n\r\n@code{\r\n    string title=\"Hello Blazor!\";\r\n\r\n    async void openDialog(){\r\n        await js.InvokeVoidAsync(\"alert\",title);\r\n    }\r\n}\r\n<\/code><\/pre>\n<h3>\u89d2\u5411<\/h3>\n<p>\u53ef\u4ee5\u4f7f\u7528(click)\u5c5e\u6027\u4ee3\u66ffonclick\u5c5e\u6027\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;button (click)=\"openDialog()\"&gt;Click Me!&lt;\/button&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">EventHandler<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">EventHandlerComponent<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">title<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Hello Angular!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"nx\">openDialog<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"nx\">alert<\/span><span class=\"p\">(<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">title<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>9. \u76d1\u542c\u4e8b\u4ef6<\/h2>\n<p>\u5728Vue.js\/Angular\u4e2d\uff0c\u4f60\u53ef\u4ee5\u540c\u65f6\u4f7f\u7528@change\u4e8b\u4ef6\u548cv-model\/[(ngModel)]\uff0c\u4f46\u5728Blazor\u4e2d\uff0c\u65e0\u6cd5\u540c\u65f6\u4f7f\u7528@onchange\u4e8b\u4ef6\u548c@bind\u3002<\/p>\n<p>\u7531\u65bcChange\u4e8b\u4ef6\u5728\u96d9\u5411\u7d81\u5b9a\u64cd\u4f5c\u4e2d\u5167\u90e8\u4f7f\u7528\uff0c\u56e0\u6b64\u53ef\u4ee5\u901a\u904e\u8a2d\u7f6e\u5c6c\u6027\uff08get\/set\uff09\u4f86\u63a5\u6536\u4e8b\u4ef6\u89f8\u767c\u3002<\/p>\n<h3>Vue.js (\u4e2d\u6587: \u524d\u7aef\u6846\u67b6Vue.js)<\/h3>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Check: <span class=\"si\">{{<\/span><span class=\"nx\">isChecked<\/span><span class=\"si\">}}<\/span><span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n    <span class=\"nt\">&lt;input<\/span> <span class=\"na\">id=<\/span><span class=\"s\">chk<\/span> <span class=\"na\">type=<\/span><span class=\"s\">checkbox<\/span> <span class=\"na\">v-model=<\/span><span class=\"s\">\"chkChange\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;label<\/span> <span class=\"na\">for=<\/span><span class=\"s\">chk<\/span><span class=\"nt\">&gt;<\/span>CheckBox<span class=\"nt\">&lt;\/label&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">OnChangeEvent<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">isChecked<\/span><span class=\"o\">=<\/span><span class=\"kc\">false<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"kd\">get<\/span> <span class=\"nx\">chkChange<\/span><span class=\"p\">(){<\/span><span class=\"k\">return<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">isChecked<\/span><span class=\"p\">;}<\/span>\r\n    <span class=\"kd\">set<\/span> <span class=\"nx\">chkChange<\/span><span class=\"p\">(<\/span><span class=\"nx\">value<\/span><span class=\"p\">:<\/span><span class=\"nx\">boolean<\/span><span class=\"p\">){<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">isChecked<\/span><span class=\"o\">=<\/span><span class=\"nx\">value<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"nx\">alert<\/span><span class=\"p\">(<\/span><span class=\"s2\">`Check: <\/span><span class=\"p\">${<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">isChecked<\/span><span class=\"p\">}<\/span><span class=\"s2\">`<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u5e03\u62c9\u6cfd\u5c14<\/h3>\n<pre class=\"post-pre\"><code>@page \"\/OnChangeEvent\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Check: @isChecked<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n    <span class=\"nt\">&lt;input<\/span> <span class=\"na\">id=<\/span><span class=\"s\">chk<\/span> <span class=\"na\">type=<\/span><span class=\"s\">checkbox<\/span> <span class=\"err\">@<\/span><span class=\"na\">bind=<\/span><span class=\"s\">\"chkChange\"<\/span><span class=\"nt\">&gt;<\/span>@(\"\"\r\n    )<span class=\"nt\">&lt;label<\/span> <span class=\"na\">for=<\/span><span class=\"s\">chk<\/span><span class=\"nt\">&gt;<\/span>CheckBox<span class=\"nt\">&lt;\/label&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@inject IJSRuntime js;\r\n\r\n@code{\r\n    bool isChecked=false;\r\n\r\n    bool chkChange{\r\n        get{return isChecked;}\r\n        set{\r\n            isChecked=value;\r\n            _=js.InvokeVoidAsync(\"alert\",$\"Check: {isChecked}\");\r\n        }\r\n    }\r\n}\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h1&gt;Check: {{isChecked}}&lt;\/h1&gt;\r\n    &lt;input id=chk type=checkbox [(ngModel)]=\"chkChange\"&gt;\r\n    &lt;label for=chk&gt;CheckBox&lt;\/label&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">OnChangeEvent<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">OnChangeEventComponent<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">isChecked<\/span><span class=\"o\">=<\/span><span class=\"kc\">false<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"kd\">get<\/span> <span class=\"nx\">chkChange<\/span><span class=\"p\">(){<\/span><span class=\"k\">return<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">isChecked<\/span><span class=\"p\">;}<\/span>\r\n    <span class=\"kd\">set<\/span> <span class=\"nx\">chkChange<\/span><span class=\"p\">(<\/span><span class=\"nx\">value<\/span><span class=\"p\">:<\/span><span class=\"nx\">boolean<\/span><span class=\"p\">){<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">isChecked<\/span><span class=\"o\">=<\/span><span class=\"nx\">value<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"nx\">alert<\/span><span class=\"p\">(<\/span><span class=\"s2\">`Check: <\/span><span class=\"p\">${<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">isChecked<\/span><span class=\"p\">}<\/span><span class=\"s2\">`<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>10. \u6837\u5f0f\u7ed1\u5b9a<\/h2>\n<p>\u5728html\u4e2d\uff0c\u4f7f\u7528\u811a\u672c\u6765\u6539\u53d8\u6837\u5f0f\u901a\u5e38\u662f\u901a\u8fc7\u66f4\u6539document.element.style\u6765\u5b8c\u6210\u7684\u3002\u4f46\u5728Vue.js\/Blazor\/Angular\u4e2d\uff0c\u6211\u4eec\u53ef\u4ee5\u76f4\u63a5\u5c06\u503c\u7ed1\u5b9a\u5230\u5c5e\u6027\u4e0a\u6765\u5b9e\u73b0\u6837\u5f0f\u7684\u53d8\u66f4\u3002<\/p>\n<h3>Vue.js \u662f\u4e00\u79cd\u6d41\u884c\u7684JavaScript\u6846\u67b6\u3002<\/h3>\n<p>\u5c06v-bind:style\u5c5e\u6027\u7684\u503c\u4ee5JSON\u683c\u5f0f\u7684\u5b57\u7b26\u4e32\u4f20\u9012\u3002<br \/>\n\u8981\u66f4\u6539\u7684\u6837\u5f0f\u952e\uff0c\u7f16\u5199\u8fd4\u56de\u6837\u5f0f\u5b57\u7b26\u4e32\u7684\u4ee3\u7801\uff0c<br \/>\n\u6216\u8005\u5c06\u5305\u542b\u6837\u5f0f\u7684\u5b57\u7b26\u4e32\u53d8\u91cf\u5206\u914d\u7ed9\u8be5\u952e\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Check: <span class=\"si\">{{<\/span><span class=\"nx\">isChecked<\/span><span class=\"si\">}}<\/span><span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n    <span class=\"nt\">&lt;input<\/span> <span class=\"na\">id=<\/span><span class=\"s\">chk<\/span> <span class=\"na\">type=<\/span><span class=\"s\">checkbox<\/span> <span class=\"na\">v-model=<\/span><span class=\"s\">\"isChecked\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;label<\/span> <span class=\"na\">for=<\/span><span class=\"s\">chk<\/span><span class=\"nt\">&gt;<\/span>CheckBox<span class=\"nt\">&lt;\/label&gt;<\/span>\r\n    <span class=\"nt\">&lt;div<\/span> <span class=\"na\">:style=<\/span><span class=\"s\">\"<\/span>{color: isChecked? 'blue': 'red'}\"&gt;\r\n        Change Style!\r\n    <span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">BindingStyle<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">isChecked<\/span><span class=\"o\">=<\/span><span class=\"kc\">false<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u4f7f\u7528Blazor<\/h3>\n<p>\u901a\u8fc7\u66f4\u6539\u4f20\u9012\u7ed9style\u5c5e\u6027\u7684\u5b57\u7b26\u4e32\uff0c\u8fdb\u884c\u6837\u5f0f\u7684\u4fee\u6539\u3002<br \/>\n\uff08\u5fc5\u987b\u4ee5CSS\u7684\u683c\u5f0f\u4f5c\u4e3a\u5b57\u7b26\u4e32\u63d0\u4f9b\uff09<\/p>\n<pre class=\"post-pre\"><code>@page \"\/BindingStyle\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Check: @isChecked<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n    <span class=\"nt\">&lt;input<\/span> <span class=\"na\">id=<\/span><span class=\"s\">chk<\/span> <span class=\"na\">type=<\/span><span class=\"s\">checkbox<\/span> <span class=\"err\">@<\/span><span class=\"na\">bind=<\/span><span class=\"s\">\"isChecked\"<\/span><span class=\"nt\">&gt;<\/span>@(\"\"\r\n    )<span class=\"nt\">&lt;label<\/span> <span class=\"na\">for=<\/span><span class=\"s\">chk<\/span><span class=\"nt\">&gt;<\/span>CheckBox<span class=\"nt\">&lt;\/label&gt;<\/span>\r\n    <span class=\"nt\">&lt;div<\/span> <span class=\"na\">style=<\/span><span class=\"s\">@(\"color:\"+(isChecked?<\/span> <span class=\"err\">\"<\/span><span class=\"na\">blue<\/span><span class=\"err\">\"<\/span><span class=\"na\">:<\/span> <span class=\"err\">\"<\/span><span class=\"na\">red<\/span><span class=\"err\">\"))<\/span><span class=\"nt\">&gt;<\/span>\r\n        Change Style!\r\n    <span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@code{\r\n    bool isChecked=false;\r\n}\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6\u6d4b\u91cf<\/h3>\n<p>\u901a\u8fc7\u66f4\u6539\u4f20\u9012\u7ed9[style.\u25cb\u25cb]\u5c5e\u6027\u7684\u5b57\u7b26\u4e32\u6765\u8fdb\u884c\u6837\u5f0f\u7684\u66f4\u6539\u3002<br \/>\n\u5728\u25cb\u25cb\u4e2d\uff0c\u63cf\u8ff0\u66f4\u6539\u540e\u7684\u6837\u5f0f\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h1&gt;Check: {{isChecked}}&lt;\/h1&gt;\r\n    &lt;input id=chk type=checkbox [(ngModel)]=\"isChecked\"&gt;\r\n    &lt;label for=chk&gt;CheckBox&lt;\/label&gt;\r\n    &lt;div [style.color]=\"isChecked? 'blue': 'red'\"&gt;\r\n        Change Style!\r\n    &lt;\/div&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">BindingStyle<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">BindingStyleComponent<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">isChecked<\/span><span class=\"o\">=<\/span><span class=\"kc\">false<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>11. \u7c7b\u7ed1\u5b9a<\/h2>\n<p>\u5173\u4e8e\u8bfe\u7a0b\uff0c\u60a8\u4e5f\u53ef\u4ee5\u50cf\u98ce\u683c\u4e00\u6837\u8fdb\u884c\u7ed1\u5b9a\u3002<\/p>\n<h3>Vue.js\uff08\u4e5f\u79f0\u4e3aVue\uff09\u662f\u4e00\u4e2a\u6d41\u884c\u7684JavaScript\u6846\u67b6\uff0c\u88ab\u5e7f\u6cdb\u7528\u4e8e\u6784\u5efa\u7528\u6237\u754c\u9762\u548c\u5355\u9875\u9762\u5e94\u7528\u7a0b\u5e8f\u3002<\/h3>\n<p>\u5c06JSON\u683c\u5f0f\u7684\u5b57\u7b26\u4e32\u4f5c\u4e3av-bind:class\u5c5e\u6027\u4f20\u9012\u3002<br \/>\n\u5c06\u8981\u66f4\u6539\u7684\u7c7b\u540d\u952e\u5206\u914d\u4e3a\u5e03\u5c14\u503c\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Check: <span class=\"si\">{{<\/span><span class=\"nx\">isChecked<\/span><span class=\"si\">}}<\/span><span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n    <span class=\"nt\">&lt;input<\/span> <span class=\"na\">id=<\/span><span class=\"s\">chk<\/span> <span class=\"na\">type=<\/span><span class=\"s\">checkbox<\/span> <span class=\"na\">v-model=<\/span><span class=\"s\">\"isChecked\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;label<\/span> <span class=\"na\">for=<\/span><span class=\"s\">chk<\/span><span class=\"nt\">&gt;<\/span>CheckBox<span class=\"nt\">&lt;\/label&gt;<\/span>\r\n    <span class=\"nt\">&lt;div<\/span> <span class=\"na\">:class=<\/span><span class=\"s\">\"<\/span>{clsA: isChecked, clsB: !isChecked}\"&gt;\r\n        Change Style!\r\n    <span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">style<\/span> <span class=\"na\">scoped<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nc\">.clsA<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">color<\/span><span class=\"p\">:<\/span> <span class=\"no\">blue<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">font-size<\/span><span class=\"p\">:<\/span> <span class=\"m\">1.5em<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">text-decoration<\/span><span class=\"p\">:<\/span> <span class=\"nb\">underline<\/span> <span class=\"nb\">solid<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"nc\">.clsB<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">color<\/span><span class=\"p\">:<\/span> <span class=\"no\">red<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">font-size<\/span><span class=\"p\">:<\/span> <span class=\"m\">1.0em<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">font-style<\/span><span class=\"p\">:<\/span> <span class=\"nb\">italic<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">BindingClass<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">isChecked<\/span><span class=\"o\">=<\/span><span class=\"kc\">false<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>Blazor = \u878d\u5408<\/h3>\n<p>\u76f4\u63a5\u7f16\u8f91class\u5c5e\u6027\u4e2d\u4f20\u9012\u7684\u5b57\u7b26\u4e32\uff0c\u5c31\u50cf\u4fee\u6539\u6837\u5f0f\u4e00\u6837\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/BindingClass\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Check: @isChecked<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n    <span class=\"nt\">&lt;input<\/span> <span class=\"na\">id=<\/span><span class=\"s\">chk<\/span> <span class=\"na\">type=<\/span><span class=\"s\">checkbox<\/span> <span class=\"err\">@<\/span><span class=\"na\">bind=<\/span><span class=\"s\">\"isChecked\"<\/span><span class=\"nt\">&gt;<\/span>@(\"\"\r\n    )<span class=\"nt\">&lt;label<\/span> <span class=\"na\">for=<\/span><span class=\"s\">chk<\/span><span class=\"nt\">&gt;<\/span>CheckBox<span class=\"nt\">&lt;\/label&gt;<\/span>\r\n    <span class=\"nt\">&lt;div<\/span> <span class=\"na\">class=<\/span><span class=\"s\">@(isChecked?<\/span> <span class=\"err\">\"<\/span><span class=\"na\">clsA<\/span><span class=\"err\">\"<\/span><span class=\"na\">:<\/span> <span class=\"err\">\"<\/span><span class=\"na\">clsB<\/span><span class=\"err\">\")<\/span><span class=\"nt\">&gt;<\/span>\r\n        Change Style!\r\n    <span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nc\">.clsA<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">color<\/span><span class=\"p\">:<\/span> <span class=\"no\">blue<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">font-size<\/span><span class=\"p\">:<\/span> <span class=\"m\">1.5em<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">text-decoration<\/span><span class=\"p\">:<\/span> <span class=\"nb\">underline<\/span> <span class=\"nb\">solid<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"nc\">.clsB<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">color<\/span><span class=\"p\">:<\/span> <span class=\"no\">red<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">font-size<\/span><span class=\"p\">:<\/span> <span class=\"m\">1.0em<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">font-style<\/span><span class=\"p\">:<\/span> <span class=\"nb\">italic<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n@code{\r\n    bool isChecked=false;\r\n}\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<p>\u5c06boolean\u503c\u5206\u914d\u7ed9[class.\u25cb\u25cb]\u5c5e\u6027\uff0c\u4ee5\u5207\u6362\u5e94\u7528\/\u4e0d\u9002\u7528\u72b6\u6001\u3002\u5728\u25cb\u25cb\u4e2d\u5199\u4e0b\u76f8\u5e94\u7684\u7c7b\u540d\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h1&gt;Check: {{isChecked}}&lt;\/h1&gt;\r\n    &lt;input id=chk type=checkbox [(ngModel)]=\"isChecked\"&gt;\r\n    &lt;label for=chk&gt;CheckBox&lt;\/label&gt;\r\n    &lt;div [class.clsA]=\"isChecked\" [class.clsB]=\"!isChecked\"&gt;\r\n        Change Style!\r\n    &lt;\/div&gt;\r\n&lt;\/div&gt;\r\n\r\n&lt;style&gt;\r\n.clsA{\r\n    color: blue;\r\n    font-size: 1.5em;\r\n    text-decoration: underline solid;\r\n}\r\n\r\n.clsB{\r\n    color: red;\r\n    font-size: 1.0em;\r\n    font-style: italic;\r\n}\r\n&lt;\/style&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">BindingClass<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">BindingClassComponent<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">isChecked<\/span><span class=\"o\">=<\/span><span class=\"kc\">false<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>12. \u5982\u679c\uff08\u6761\u4ef6\uff09\u968f\u673a\u5206\u914d\u3002<\/h2>\n<p>\u5728Vue.js\/Blazor\/Angular\u4e2d\uff0c\u53ef\u4ee5\u901a\u8fc7\u6761\u4ef6\u5206\u652f\u6765\u6539\u53d8\u663e\u793a\u72b6\u6001\u3002<\/p>\n<h3>Vue.js \u662f\u4e00\u4e2a\u7528\u4e8e\u6784\u5efa\u7528\u6237\u754c\u9762\u7684\u6e10\u8fdb\u5f0f JavaScript \u6846\u67b6\u3002<\/h3>\n<p>\u5f53\u5c06v-if\u5c5e\u6027\u5305\u542b\u5728\u76ee\u6807\u5143\u7d20\u4e2d\u65f6\uff0c\u53ef\u4ee5\u6539\u53d8\u5176\u663e\u793a\u72b6\u6001\u3002<br \/>\n\u4f7f\u7528v-if\u8fdb\u884c\u663e\u793a\u5207\u6362\u4f1a\u89e6\u53d1\u751f\u547d\u5468\u671f\u3002<br \/>\n\u5982\u679c\u5e0c\u671b\u4fdd\u6301\u7ec4\u4ef6\u7684\u72b6\u6001\u5e76\u8fdb\u884c\u663e\u793a\u5207\u6362\uff0c\u53ef\u4ee5\u4f7f\u7528v-show\u3002<br \/>\n\uff08\u5176\u5185\u90e8\u4f7f\u7528display: none;\uff09<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Check: <span class=\"si\">{{<\/span><span class=\"nx\">isChecked<\/span><span class=\"si\">}}<\/span><span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n    <span class=\"nt\">&lt;input<\/span> <span class=\"na\">id=<\/span><span class=\"s\">chk<\/span> <span class=\"na\">type=<\/span><span class=\"s\">checkbox<\/span> <span class=\"na\">v-model=<\/span><span class=\"s\">\"isChecked\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;label<\/span> <span class=\"na\">for=<\/span><span class=\"s\">chk<\/span><span class=\"nt\">&gt;<\/span>CheckBox<span class=\"nt\">&lt;\/label&gt;<\/span>\r\n    <span class=\"nt\">&lt;div<\/span> <span class=\"na\">v-if=<\/span><span class=\"s\">\"isChecked\"<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"nt\">&lt;input&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/div&gt;<\/span>\r\n    <span class=\"nt\">&lt;div<\/span> <span class=\"na\">v-show=<\/span><span class=\"s\">\"isChecked\"<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"nt\">&lt;input&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">IfAndShow<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">isChecked<\/span><span class=\"o\">=<\/span><span class=\"kc\">false<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>Blazor\u86c7\u5e74\u7684\u5e72\u71e5\u5f88\u6709\u5229\u3002<\/h3>\n<p>\u4f7f\u7528@if\u3002<br \/>\n\u5728\u884c\u4e3a\u4e0a\u4e0eVue.js\u4e2d\u7684v-if\u76f8\u540c\u3002<br \/>\n\u5982\u679c\u8981\u4fdd\u6301\u7ec4\u4ef6\u7684\u72b6\u6001\uff0c\u53ef\u4ee5\u76f4\u63a5\u5728style\/class\u5c5e\u6027\u4e2d\u9690\u85cf\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/IfAndShow\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Check: @isChecked<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n    <span class=\"nt\">&lt;input<\/span> <span class=\"na\">id=<\/span><span class=\"s\">chk<\/span> <span class=\"na\">type=<\/span><span class=\"s\">checkbox<\/span> <span class=\"err\">@<\/span><span class=\"na\">bind=<\/span><span class=\"s\">\"isChecked\"<\/span><span class=\"nt\">&gt;<\/span>@(\"\"\r\n    )<span class=\"nt\">&lt;label<\/span> <span class=\"na\">for=<\/span><span class=\"s\">chk<\/span><span class=\"nt\">&gt;<\/span>CheckBox<span class=\"nt\">&lt;\/label&gt;<\/span>\r\n    @if(isChecked){\r\n        <span class=\"nt\">&lt;div&gt;<\/span>\r\n            <span class=\"nt\">&lt;input&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/div&gt;<\/span>\r\n    }\r\n    <span class=\"nt\">&lt;div<\/span> <span class=\"na\">style=<\/span><span class=\"s\">@(\"display:\"+(isChecked?<\/span> <span class=\"err\">\"\"<\/span><span class=\"na\">:<\/span> <span class=\"err\">\"<\/span><span class=\"na\">none<\/span><span class=\"err\">\"))<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"nt\">&lt;input&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@code{\r\n    bool isChecked=false;\r\n}\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<p>\u5982\u679c\u8981\u4fdd\u6301\u7ec4\u4ef6\u7684\u72b6\u6001\u5e76\u4f7f\u5176\u9690\u85cf\uff0c\u53ef\u4ee5\u4f7f\u7528[style.display]\u5c5e\u6027\u5c06\u5176\u8bbe\u7f6e\u4e3a\u201cnone\u201d\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h1&gt;Check: {{isChecked}}&lt;\/h1&gt;\r\n    &lt;input id=chk type=checkbox [(ngModel)]=\"isChecked\"&gt;\r\n    &lt;label for=chk&gt;CheckBox&lt;\/label&gt;\r\n    &lt;div *ngIf=\"isChecked\"&gt;\r\n        &lt;input&gt;\r\n    &lt;\/div&gt;\r\n    &lt;div [style.display]=\"isChecked? '': 'none'\"&gt;\r\n        &lt;input&gt;\r\n    &lt;\/div&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">IfAndShow<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">IfAndShowComponent<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">isChecked<\/span><span class=\"o\">=<\/span><span class=\"kc\">false<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>13. \u904d\u5386(\u5faa\u73af)<\/h2>\n<p>\u5728Vue.js \/ Blazor \/ Angular\u4e2d\uff0c\u5982\u679c\u5177\u6709\u76f8\u540c\u7684\u914d\u7f6e\u6807\u7b7e\uff0c\u5219\u53ef\u4ee5\u91cd\u590d\u663e\u793a\u5b83\u4eec\u3002<\/p>\n<h3>\u5173\u4e8ev-bind:key\/@key<\/h3>\n<p>\u4e3a\u4e86\u786e\u4fdd\u5728\u5faa\u73af\u751f\u6210\u7684\u5217\u8868\u4e2d\u7ec4\u4ef6\u7684\u552f\u4e00\u6027\u7b49\u65b9\u9762\uff0c\u5efa\u8bae\u6dfb\u52a0key\u5c5e\u6027\u3002<br \/>\n\uff08\u5728Blazor\u4e2d\u4e0d\u63a8\u8350\u4f7f\u7528\uff1f\uff09<br \/>\n\u636e\u8bf4\u8fd9\u6837\u53ef\u4ee5\u63d0\u9ad8\u6027\u80fd\u3002<br \/>\n\u5728Vue.js\u4e2d\u4f7f\u7528v-bind:key\uff0c\u5728Blazor\u4e2d\u4f7f\u7528@key\u3002<\/p>\n<h3>Vue.js \uff08\u539f\u540d\u4e3aVue\uff09\u662f\u4e00\u4e2a\u7528\u4e8e\u6784\u5efa\u7528\u6237\u754c\u9762\u7684\u6e10\u8fdb\u5f0fJavaScript\u6846\u67b6\u3002<\/h3>\n<p>\u5c06\u60f3\u8981\u91cd\u590d\u7684\u5143\u7d20\u5305\u542b\u5728v-for\u5c5e\u6027\u4e2d\u3002<br \/>\n\u8fd9\u53ef\u4ee5\u4f7f\u7528template\u6807\u7b7e\u4f5c\u4e3a\u65e0\u540d\u6807\u7b7e\u5e76\u5c06\u5176\u5305\u56f4\u8d77\u6765\u8fdb\u884c\u5faa\u73af\uff0c\u6ca1\u6709\u95ee\u9898\u3002<br \/>\n\u5728\u5927\u591a\u6570\u4e3b\u6d41\u6d4f\u89c8\u5668\u4e2d\uff0c\u5bf9\u8c61\u7684\u987a\u5e8f\u662f\u786e\u5b9a\u7684\uff0c\u4f46\u8bf7\u6ce8\u610f\u89c4\u8303\u4e0a\u5e76\u4e0d\u4fdd\u8bc1\u8fd9\u4e00\u70b9\u3002<br \/>\n\uff08\u867d\u7136\u4e5f\u53ef\u4ee5\u4f7f\u7528Map\uff0c\u4f46\u4fe1\u606f\u91cf\u8f83\u5c11\uff0c\u6709\u4e9b\u53ef\u7591\u3002<br \/>\n\u6839\u636e\u5e38\u89c4\u7684for\u5faa\u73af\u65b9\u5f0f\u5199\u6210v-for=&#8221;[key, value] of list&#8221;\uff0c\u4f3c\u4e4e\u53ef\u4ee5\u4f7f\u7528\u3002\uff09<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;div<\/span> <span class=\"na\">v-for=<\/span><span class=\"s\">\"(isChecked,key) in dict\"<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"nt\">&lt;input<\/span> <span class=\"na\">:id=<\/span><span class=\"s\">\"key\"<\/span> <span class=\"na\">type=<\/span><span class=\"s\">checkbox<\/span> <span class=\"na\">v-model=<\/span><span class=\"s\">\"dict[key]\"<\/span> <span class=\"na\">:key=<\/span><span class=\"s\">\"key\"<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"nt\">&lt;label<\/span> <span class=\"na\">:for=<\/span><span class=\"s\">\"key\"<\/span><span class=\"nt\">&gt;<\/span><span class=\"si\">{{<\/span><span class=\"nx\">key<\/span><span class=\"si\">}}<\/span><span class=\"nt\">&lt;\/label&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ForEachLoop<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">dict<\/span><span class=\"p\">:{[<\/span><span class=\"na\">s<\/span><span class=\"p\">:<\/span><span class=\"nx\">string<\/span><span class=\"p\">]:<\/span><span class=\"nx\">boolean<\/span><span class=\"p\">}<\/span><span class=\"o\">=<\/span><span class=\"p\">{<\/span>\r\n        <span class=\"na\">A<\/span><span class=\"p\">:<\/span><span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"na\">B<\/span><span class=\"p\">:<\/span><span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"na\">C<\/span><span class=\"p\">:<\/span><span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"na\">D<\/span><span class=\"p\">:<\/span><span class=\"kc\">false<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"na\">E<\/span><span class=\"p\">:<\/span><span class=\"kc\">false<\/span>\r\n    <span class=\"p\">};<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u84dd\u5149<\/h3>\n<p>\u4f7f\u7528@for\/@foreach\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/ForEachLoop\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    @foreach(var (key,isChecked) in dict){\r\n        <span class=\"nt\">&lt;div&gt;<\/span>\r\n            <span class=\"nt\">&lt;input<\/span> <span class=\"na\">id=<\/span><span class=\"s\">@key<\/span> <span class=\"na\">type=<\/span><span class=\"s\">checkbox<\/span> <span class=\"err\">@<\/span><span class=\"na\">bind=<\/span><span class=\"s\">\"dict[key]\"<\/span> <span class=\"err\">@<\/span><span class=\"na\">key=<\/span><span class=\"s\">\"key\"<\/span><span class=\"nt\">&gt;<\/span>@(\"\"\r\n            )<span class=\"nt\">&lt;label<\/span> <span class=\"na\">for=<\/span><span class=\"s\">@key<\/span><span class=\"nt\">&gt;<\/span>@key<span class=\"nt\">&lt;\/label&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/div&gt;<\/span>\r\n    }\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@code{\r\n    Dictionary<span class=\"nt\">&lt;string<\/span><span class=\"err\">,<\/span><span class=\"na\">bool<\/span><span class=\"nt\">&gt;<\/span> dict=new Dictionary<span class=\"nt\">&lt;string<\/span><span class=\"err\">,<\/span><span class=\"na\">bool<\/span><span class=\"nt\">&gt;<\/span>{\r\n        {\"A\",true},\r\n        {\"B\",true},\r\n        {\"C\",true},\r\n        {\"D\",false},\r\n        {\"E\",false}\r\n    };\r\n}\r\n<\/code><\/pre>\n<h3>Angular \uff08\u89d2\u5ea6\uff09<\/h3>\n<p>\u53ef\u4ee5\u628a *ngFor \u5c5e\u6027\u5e94\u7528\u5230\u60f3\u8981\u5faa\u73af\u7684\u5143\u7d20\u4e2d\u3002<br \/>\n\u4e0e Vue.js \u7684\u6a21\u677f\u7c7b\u4f3c\uff0c\u53ef\u4ee5\u5c06 ng-container \u7528\u4f5c~\u5143\u7d20\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;div *ngFor=\"let v of dict | keyvalue\"&gt;\r\n        &lt;input [id]=\"v.key\" type=checkbox [(ngModel)]=\"dict[v.key]\"&gt;\r\n        &lt;label [for]=\"v.key\"&gt;{{v.key}}&lt;\/label&gt;\r\n    &lt;\/div&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">ForEachLoop<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ForEachLoopComponent<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">dict<\/span><span class=\"p\">:{[<\/span><span class=\"na\">s<\/span><span class=\"p\">:<\/span><span class=\"kr\">string<\/span><span class=\"p\">]:<\/span><span class=\"nx\">boolean<\/span><span class=\"p\">}<\/span><span class=\"o\">=<\/span><span class=\"p\">{<\/span>\r\n        <span class=\"na\">A<\/span><span class=\"p\">:<\/span><span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"na\">B<\/span><span class=\"p\">:<\/span><span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"na\">C<\/span><span class=\"p\">:<\/span><span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"na\">D<\/span><span class=\"p\">:<\/span><span class=\"kc\">false<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"na\">E<\/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<h2>14. \u6dfb\u52a0\u7ec4\u4ef6<\/h2>\n<p>\u5728Vue.js\/Blazor\/Angular\u4e2d\uff0c\u4f60\u53ef\u4ee5\u5c06\u81ea\u5b9a\u4e49\u7684\u5143\u7d20\uff08\u7ec4\u4ef6\uff09\u5d4c\u5165\u5230HTML\u6807\u7b7e\u4e2d\u3002\u5728Blazor\u4e2d\uff0c\u6240\u6709\u7684\u7ec4\u4ef6\u90fd\u4f1a\u88ab\u81ea\u52a8\u52a0\u8f7d\uff0c\u4f46\u5728Vue.js\u4e2d\uff0c\u4f60\u9700\u8981\u4f7f\u7528import\u8bed\u53e5\u6765\u6307\u5b9a\u8981\u52a0\u8f7d\u7684\u7ec4\u4ef6\u3002\u5728Angular\u4e2d\uff0c\u4f60\u9700\u8981\u5c06\u7ec4\u4ef6\u7684\u5f15\u7528\u5199\u5165app.module.ts\u6587\u4ef6\u4e2d\u3002<\/p>\n<h3>Vue.js\uff08\u4e2d\u6587\u540d\u4e3a\u201c\u89c6\u56fe\u201d\uff09\u662f\u4e00\u79cd\u7528\u4e8e\u6784\u5efa\u7528\u6237\u754c\u9762\u7684\u5f00\u6e90JavaScript\u6846\u67b6\u3002<\/h3>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;ComponentA<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n    <span class=\"nt\">&lt;ComponentB<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">ComponentA<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@\/components\/ComponentA.vue<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">ComponentB<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@\/components\/ComponentB.vue<\/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\">components<\/span><span class=\"p\">:{<\/span>\r\n        <span class=\"nx\">ComponentA<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"nx\">ComponentB<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">AddComponent<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h3&gt;<\/span>ComponentA<span class=\"nt\">&lt;\/h3&gt;<\/span>\r\n    <span class=\"nt\">&lt;textarea&gt;&lt;\/textarea&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;input<\/span> <span class=\"na\">id=<\/span><span class=\"s\">chk<\/span> <span class=\"na\">type=<\/span><span class=\"s\">checkbox<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;label<\/span> <span class=\"na\">for=<\/span><span class=\"s\">chk<\/span><span class=\"nt\">&gt;<\/span>ComponentB<span class=\"nt\">&lt;\/label&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u5e03\u62c9\u7d22<\/h3>\n<pre class=\"post-pre\"><code>@page \"\/AddComponent\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;ComponentA<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n    <span class=\"nt\">&lt;ComponentB<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h3&gt;<\/span>ComponentA<span class=\"nt\">&lt;\/h3&gt;<\/span>\r\n    <span class=\"nt\">&lt;textarea&gt;&lt;\/textarea&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;input<\/span> <span class=\"na\">id=<\/span><span class=\"s\">chk<\/span> <span class=\"na\">type=<\/span><span class=\"s\">checkbox<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;label<\/span> <span class=\"na\">for=<\/span><span class=\"s\">chk<\/span><span class=\"nt\">&gt;<\/span>ComponentB<span class=\"nt\">&lt;\/label&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;ComponentA&gt;&lt;\/ComponentA&gt;\r\n    &lt;ComponentB&gt;&lt;\/ComponentB&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">AddComponent<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">templateUrl<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">AddComponentComponent<\/span><span class=\"p\">{}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h3&gt;ComponentA&lt;\/h3&gt;\r\n    &lt;textarea&gt;&lt;\/textarea&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">ComponentA<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ComponentAComponent<\/span><span class=\"p\">{}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;input id=chk type=checkbox&gt;\r\n    &lt;label for=chk&gt;ComponentB&lt;\/label&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">ComponentB<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">templateUrl<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ComponentBComponent<\/span><span class=\"p\">{}<\/span>\r\n<\/code><\/pre>\n<h2>15. \u7ec4\u4ef6\u7684\u5c5e\u6027 de<\/h2>\n<p>\u5728Vue.js\/Blazor\/Angular\u4e2d\uff0c\u53ef\u4ee5\u7ed9\u5b50\u7ec4\u4ef6\u6dfb\u52a0\u5c5e\u6027\uff0c\u5e76\u5728\u5b50\u7ec4\u4ef6\u4e2d\u4f5c\u4e3a\u5c5e\u6027\u4f7f\u7528\u3002<br \/>\n\u5728Vue.js\u4e2d\u4f7f\u7528@Prop\uff0c\u5728Blazor\u4e2d\u4f7f\u7528[Parameter]\uff0c\u5728Angular\u4e2d\u4f7f\u7528@Input\u6765\u6307\u5b9a\u5c5e\u6027\u540d\u3002<\/p>\n<h3>Vue.js \u662f\u4e00\u4e2a\u7528\u4e8e\u6784\u5efa\u7528\u6237\u754c\u9762\u7684\u6e10\u8fdb\u5f0fJavaScript\u6846\u67b6\u3002<\/h3>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;ComponentC<\/span> <span class=\"na\">msg=<\/span><span class=\"s\">\"View Message\"<\/span> <span class=\"na\">color=<\/span><span class=\"s\">\"#FF00FF\"<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">ComponentC<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@\/components\/ComponentC.vue<\/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\">components<\/span><span class=\"p\">:{<\/span>\r\n        <span class=\"nx\">ComponentC<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ComponentAttribute<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div<\/span> <span class=\"na\">:style=<\/span><span class=\"s\">\"<\/span>{color: color}\"&gt;\r\n    Input Attribute=<span class=\"si\">{{<\/span><span class=\"nx\">msg<\/span><span class=\"si\">}}<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Prop<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ComponentC<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"p\">@<\/span><span class=\"nd\">Prop<\/span><span class=\"p\">()<\/span>\r\n    <span class=\"kr\">private<\/span> <span class=\"nx\">msg<\/span><span class=\"p\">:<\/span><span class=\"nx\">string<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">@<\/span><span class=\"nd\">Prop<\/span><span class=\"p\">()<\/span>\r\n    <span class=\"kr\">private<\/span> <span class=\"nx\">color<\/span><span class=\"p\">:<\/span><span class=\"nx\">string<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u5e03\u96f7\u6cfd<\/h3>\n<pre class=\"post-pre\"><code>@page \"\/ComponentAttribute\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;ComponentC<\/span> <span class=\"na\">msg=<\/span><span class=\"s\">\"View Message\"<\/span> <span class=\"na\">color=<\/span><span class=\"s\">\"#FF00FF\"<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;div<\/span> <span class=\"na\">style=<\/span><span class=\"s\">@($\"color:<\/span> <span class=\"err\">{<\/span><span class=\"na\">color<\/span><span class=\"err\">}\")<\/span><span class=\"nt\">&gt;<\/span>\r\n    Input Attribute=@msg\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@code{\r\n    [Parameter]\r\n    public string msg{get;set;}\r\n    [Parameter]\r\n    public string color{get;set;}\r\n}\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;ComponentC msg=\"View Message\" color=\"#FF00FF\"&gt;&lt;\/ComponentC&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">ComponentAttribute<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ComponentAttributeComponent<\/span><span class=\"p\">{}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div [style.color]=\"color\"&gt;\r\n    Input Attribute={{msg}}\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Input<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@angular\/core<\/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=\"s2\">ComponentC<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ComponentCComponent<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"p\">@<\/span><span class=\"nd\">Input<\/span><span class=\"p\">()<\/span>\r\n    <span class=\"k\">private<\/span> <span class=\"nx\">msg<\/span><span class=\"p\">:<\/span> <span class=\"kr\">string<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">@<\/span><span class=\"nd\">Input<\/span><span class=\"p\">()<\/span>\r\n    <span class=\"k\">private<\/span> <span class=\"nx\">color<\/span><span class=\"p\">:<\/span> <span class=\"kr\">string<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>16. \u8c03\u7528\u7ec4\u4ef6\u7684\u65b9\u6cd5<\/h2>\n<p>\u5728Vue.js\/Blazor\/Angular\u4e2d\uff0c\u60a8\u53ef\u4ee5\u8c03\u7528\u5b50\u7ec4\u4ef6\u4e2d\u7684\u6210\u5458\u3002<\/p>\n<h3>Vue.js \u662f\u4e00\u79cd\u6d41\u884c\u7684\u524d\u7aef\u6846\u67b6\u3002<\/h3>\n<p>\u4e3a\u4e86\u5728ref\u5c5e\u6027\u4e2d\u7ed1\u5b9a\u53d8\u91cf\u540d\u79f0\uff0c\u8bf7\u6307\u5b9a\u9700\u8981\u58f0\u660e\u7684\u540d\u79f0\uff0c\u4ee5\u4fbf\u5728\u7c7b\u4e2d\u4f7f\u7528\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;Toast<\/span> <span class=\"na\">ref=<\/span><span class=\"s\">\"toast\"<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n    <span class=\"nt\">&lt;button<\/span> <span class=\"err\">@<\/span><span class=\"na\">click=<\/span><span class=\"s\">\"viewToast\"<\/span><span class=\"nt\">&gt;<\/span>Click Me!<span class=\"nt\">&lt;\/button&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">Toast<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@\/components\/Toast.vue<\/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\">components<\/span><span class=\"p\">:{<\/span>\r\n        <span class=\"nx\">Toast<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ComponentMethod<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">$refs<\/span><span class=\"o\">!<\/span><span class=\"p\">:{<\/span><span class=\"nl\">toast<\/span><span class=\"p\">:<\/span> <span class=\"nx\">Toast<\/span><span class=\"p\">};<\/span>\r\n\r\n    <span class=\"k\">async<\/span> <span class=\"nx\">viewToast<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"k\">await<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">$refs<\/span><span class=\"p\">.<\/span><span class=\"nx\">toast<\/span><span class=\"p\">.<\/span><span class=\"nx\">show<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">View Torst!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;dialog<\/span> <span class=\"na\">:open=<\/span><span class=\"s\">\"isShow\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"si\">{{<\/span><span class=\"nx\">msg<\/span><span class=\"si\">}}<\/span>\r\n<span class=\"nt\">&lt;\/dialog&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">,<\/span><span class=\"nx\">Prop<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">Toast<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">isShow<\/span><span class=\"o\">=<\/span><span class=\"kc\">false<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nx\">msg<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"\"<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"kr\">public<\/span> <span class=\"k\">async<\/span> <span class=\"nx\">show<\/span><span class=\"p\">(<\/span><span class=\"nx\">msg<\/span><span class=\"p\">:<\/span><span class=\"nx\">string<\/span><span class=\"p\">){<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">msg<\/span><span class=\"o\">=<\/span><span class=\"nx\">msg<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">isShow<\/span><span class=\"o\">=<\/span><span class=\"kc\">true<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"k\">await<\/span> <span class=\"k\">new<\/span> <span class=\"nb\">Promise<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"o\">=&gt;<\/span><span class=\"nx\">setTimeout<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"p\">,<\/span><span class=\"mi\">1500<\/span><span class=\"p\">));<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">isShow<\/span><span class=\"o\">=<\/span><span class=\"kc\">false<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>Blazor \u662f\u4e00\u79cd\u672c\u673a\u5728\u4e2d\u56fd\u7684\u4e2d\u6587\u7684\u8868\u8ff0\u3002<\/h3>\n<p>\u9700\u8981\u4f7f\u7528@ref\u5c5e\u6027\u6765\u6307\u5b9a\u7ed1\u5b9a\u53d8\u91cf\u7684\u540d\u79f0\u3002<br \/>\n\u4e3a\u4e86\u5728\u7c7b\u4e2d\u4f7f\u7528\u5b83\uff0c\u9700\u8981\u8fdb\u884c\u58f0\u660e\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/ComponentMethod\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;Toast<\/span> <span class=\"err\">@<\/span><span class=\"na\">ref=<\/span><span class=\"s\">\"toast\"<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n    <span class=\"nt\">&lt;button<\/span> <span class=\"err\">@<\/span><span class=\"na\">onclick=<\/span><span class=\"s\">\"viewToast\"<\/span><span class=\"nt\">&gt;<\/span>Click Me!<span class=\"nt\">&lt;\/button&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@code{\r\n    Toast toast;\r\n\r\n    async Task viewToast(){\r\n        await toast.show(\"View Toast!\");\r\n    }\r\n}\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;dialog<\/span> <span class=\"na\">open=<\/span><span class=\"s\">@isShow<\/span><span class=\"nt\">&gt;<\/span>\r\n    @msg\r\n<span class=\"nt\">&lt;\/dialog&gt;<\/span>\r\n\r\n@code{\r\n    bool isShow=false;\r\n    string msg=\"\";\r\n\r\n    public async Task show(string msg){\r\n        this.msg=msg;\r\n        isShow=true;\r\n        StateHasChanged();\r\n        await Task.Delay(2500);\r\n        isShow=false;\r\n        StateHasChanged();\r\n    }\r\n}\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<p>\u901a\u8fc7\u5f15\u5165\u7ec4\u4ef6\u5e76\u5728\u7c7b\u4e2d\u4f7f\u7528@ViewChild\u88c5\u9970\u5668\u5206\u914d\u5b83\u6765\u4f7f\u7528\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;Toast&gt;&lt;\/Toast&gt;\r\n    &lt;button (click)=\"viewToast()\"&gt;Click Me!&lt;\/button&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">ViewChild<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@angular\/core<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">ToastComponent<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">..\/components\/Toast.component<\/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=\"s2\">ComponentMethod<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ComponentMethodComponent<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"p\">@<\/span><span class=\"nd\">ViewChild<\/span><span class=\"p\">(<\/span><span class=\"nx\">ToastComponent<\/span><span class=\"p\">,{<\/span><span class=\"na\">static<\/span><span class=\"p\">:<\/span> <span class=\"kc\">false<\/span><span class=\"p\">})<\/span>\r\n    <span class=\"k\">private<\/span> <span class=\"nx\">toast<\/span><span class=\"p\">:<\/span><span class=\"nx\">ToastComponent<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"k\">async<\/span> <span class=\"nx\">viewToast<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"k\">await<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">toast<\/span><span class=\"p\">.<\/span><span class=\"nx\">show<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">View Torst!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">);<\/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=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;dialog [open]=\"isShow\"&gt;\r\n    {{msg}}\r\n&lt;\/dialog&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">Toast<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ToastComponent<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">isShow<\/span><span class=\"o\">=<\/span><span class=\"kc\">false<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nx\">msg<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"\"<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"k\">public<\/span> <span class=\"k\">async<\/span> <span class=\"nx\">show<\/span><span class=\"p\">(<\/span><span class=\"nx\">msg<\/span><span class=\"p\">:<\/span><span class=\"kr\">string<\/span><span class=\"p\">){<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">msg<\/span><span class=\"o\">=<\/span><span class=\"nx\">msg<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">isShow<\/span><span class=\"o\">=<\/span><span class=\"kc\">true<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"k\">await<\/span> <span class=\"k\">new<\/span> <span class=\"nb\">Promise<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"o\">=&gt;<\/span><span class=\"nx\">setTimeout<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"p\">,<\/span><span class=\"mi\">1500<\/span><span class=\"p\">));<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">isShow<\/span><span class=\"o\">=<\/span><span class=\"kc\">false<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>17. \u72b6\u6001\u7ba1\u7406\u5bb9\u5668<\/h2>\n<p>\u7c7b\u4f3c\u5168\u5c40\u53d8\u91cf\uff0c\u53ef\u4ee5\u4ece\u4efb\u4f55\u7ec4\u4ef6\u4e2d\u5f15\u7528\u3002<br \/>\n\u8fd9\u91cc\u53ea\u8fdb\u884c\u53d8\u91cf\u7684\u7b80\u5355\u8bfb\u5199\u64cd\u4f5c\u3002<\/p>\n<p>\u5728Vue.js\u4e2d\uff0c\u6709\u4e00\u4e2a\u5b98\u65b9\u7684\u5e93\u53eb\u4f5cVuex\u3002<br \/>\n\u5728Blazor\u4e2d\uff0c\u867d\u7136\u6ca1\u6709\u7c7b\u4f3c\u7684\u5e93\u5b58\u5728\uff0c\u4f46\u53ef\u4ee5\u901a\u8fc7Blazor\u7684\u57fa\u672c\u529f\u80fd\u6765\u5904\u7406\u5bb9\u5668\uff0c\u5b9e\u73b0\u76f8\u540c\u7684\u6548\u679c\u3002<br \/>\n\u53c2\u80031 \u53c2\u80032<br \/>\n\u5728Angular\u4e2d\uff0c\u53ef\u4ee5\u5c06\u670d\u52a1\u4f5c\u4e3a\u5bb9\u5668\u6765\u4f7f\u7528\u3002<\/p>\n<p>\u53ea\u5217\u51fa\u64cd\u4f5c\u793a\u4f8b\uff0c\u8be6\u7ec6\u5185\u5bb9\u7565\u8fc7\u3002<\/p>\n<h3>Vue.js (Chinese: Vue.js) is a progressive JavaScript framework for building user interfaces.<\/h3>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;BooksInput<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n    <span class=\"nt\">&lt;button<\/span> <span class=\"err\">@<\/span><span class=\"na\">click=<\/span><span class=\"s\">\"getBooks\"<\/span><span class=\"nt\">&gt;<\/span>Get Books!<span class=\"nt\">&lt;\/button&gt;<\/span>\r\n    <span class=\"nt\">&lt;h3&gt;<\/span>BookLists (<span class=\"si\">{{<\/span><span class=\"nx\">date<\/span><span class=\"si\">}}<\/span>)<span class=\"nt\">&lt;\/h3&gt;<\/span>\r\n    <span class=\"nt\">&lt;ul&gt;<\/span>\r\n        <span class=\"nt\">&lt;li<\/span> <span class=\"na\">v-for=<\/span><span class=\"s\">\"book in books\"<\/span> <span class=\"na\">:key=<\/span><span class=\"s\">\"book\"<\/span><span class=\"nt\">&gt;<\/span><span class=\"si\">{{<\/span><span class=\"nx\">book<\/span><span class=\"si\">}}<\/span><span class=\"nt\">&lt;\/li&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/ul&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">BooksInput<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@\/components\/BooksInput.vue<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">store<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@\/store<\/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\">components<\/span><span class=\"p\">:{<\/span>\r\n        <span class=\"nx\">BooksInput<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">StateContainer<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">books<\/span><span class=\"p\">:<\/span><span class=\"nx\">string<\/span><span class=\"p\">[]<\/span><span class=\"o\">=<\/span><span class=\"p\">[];<\/span>\r\n    <span class=\"nl\">date<\/span><span class=\"p\">:<\/span><span class=\"nb\">Date<\/span><span class=\"o\">=<\/span><span class=\"kc\">null<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"nx\">getBooks<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">books<\/span><span class=\"o\">=<\/span><span class=\"nx\">store<\/span><span class=\"p\">.<\/span><span class=\"nx\">state<\/span><span class=\"p\">.<\/span><span class=\"nx\">books<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">date<\/span><span class=\"o\">=<\/span><span class=\"nx\">store<\/span><span class=\"p\">.<\/span><span class=\"nx\">state<\/span><span class=\"p\">.<\/span><span class=\"nx\">date<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;div&gt;&lt;textarea<\/span> <span class=\"na\">v-model=<\/span><span class=\"s\">\"bookList\"<\/span> <span class=\"na\">id=<\/span><span class=\"s\">\"bookList\"<\/span><span class=\"nt\">&gt;&lt;\/textarea&gt;&lt;\/div&gt;<\/span>\r\n    <span class=\"nt\">&lt;button<\/span> <span class=\"err\">@<\/span><span class=\"na\">click=<\/span><span class=\"s\">\"setBooks\"<\/span><span class=\"nt\">&gt;<\/span>Set Books!<span class=\"nt\">&lt;\/button&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">style<\/span> <span class=\"na\">scoped<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nf\">#bookList<\/span><span class=\"p\">{<\/span>\r\n        <span class=\"nl\">height<\/span><span class=\"p\">:<\/span> <span class=\"m\">300px<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"nl\">width<\/span><span class=\"p\">:<\/span> <span class=\"m\">300px<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">,<\/span><span class=\"nx\">Prop<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">store<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@\/store<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">BooksInput<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">bookList<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"\"<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"kr\">public<\/span> <span class=\"nx\">setBooks<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"nx\">store<\/span><span class=\"p\">.<\/span><span class=\"nx\">commit<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">setBooks<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">bookList<\/span><span class=\"p\">.<\/span><span class=\"nx\">split<\/span><span class=\"p\">(<\/span><span class=\"sr\">\/<\/span><span class=\"se\">\\r<\/span><span class=\"sr\">|<\/span><span class=\"se\">\\n<\/span><span class=\"sr\">|<\/span><span class=\"se\">\\r\\n<\/span><span class=\"sr\">\/<\/span><span class=\"p\">).<\/span><span class=\"nx\">filter<\/span><span class=\"p\">(<\/span><span class=\"nx\">s<\/span><span class=\"o\">=&gt;<\/span><span class=\"nx\">s<\/span><span class=\"o\">!=<\/span><span class=\"dl\">\"\"<\/span><span class=\"p\">));<\/span>\r\n        <span class=\"nx\">store<\/span><span class=\"p\">.<\/span><span class=\"nx\">commit<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">setDate<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span><span class=\"k\">new<\/span> <span class=\"nb\">Date<\/span><span class=\"p\">());<\/span>\r\n        <span class=\"nx\">alert<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">setBooks!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"nx\">Vue<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">Vuex<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vuex<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"nx\">Vue<\/span><span class=\"p\">.<\/span><span class=\"nx\">use<\/span><span class=\"p\">(<\/span><span class=\"nx\">Vuex<\/span><span class=\"p\">);<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"k\">new<\/span> <span class=\"nx\">Vuex<\/span><span class=\"p\">.<\/span><span class=\"nx\">Store<\/span><span class=\"p\">({<\/span>\r\n    <span class=\"na\">state<\/span><span class=\"p\">:{<\/span>\r\n        <span class=\"na\">books<\/span><span class=\"p\">:<\/span> <span class=\"p\">[]<\/span> <span class=\"k\">as<\/span> <span class=\"kr\">string<\/span><span class=\"p\">[],<\/span>\r\n        <span class=\"na\">date<\/span><span class=\"p\">:<\/span> <span class=\"kc\">null<\/span> <span class=\"k\">as<\/span> <span class=\"nb\">Date<\/span>\r\n    <span class=\"p\">},<\/span>\r\n    <span class=\"na\">mutations<\/span><span class=\"p\">:{<\/span>\r\n        <span class=\"nx\">setBooks<\/span><span class=\"p\">(<\/span><span class=\"nx\">state<\/span><span class=\"p\">,<\/span><span class=\"na\">books<\/span><span class=\"p\">:<\/span><span class=\"kr\">string<\/span><span class=\"p\">[]){<\/span>\r\n            <span class=\"nx\">state<\/span><span class=\"p\">.<\/span><span class=\"nx\">books<\/span><span class=\"o\">=<\/span><span class=\"nx\">books<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"p\">},<\/span>\r\n        <span class=\"nx\">setDate<\/span><span class=\"p\">(<\/span><span class=\"nx\">state<\/span><span class=\"p\">,<\/span><span class=\"na\">date<\/span><span class=\"p\">:<\/span><span class=\"nb\">Date<\/span><span class=\"p\">){<\/span>\r\n            <span class=\"nx\">state<\/span><span class=\"p\">.<\/span><span class=\"nx\">date<\/span><span class=\"o\">=<\/span><span class=\"nx\">date<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"p\">}<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">});<\/span>\r\n<\/code><\/pre>\n<h3>\u201d\u84dd\u5c24\u201c<\/h3>\n<p>\u9700\u8981\u5c06\u5bb9\u5668\u6ce8\u518c\u4e3a\u670d\u52a1\u4e8e Program.cs\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/StateContainer\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;BooksInput<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n    <span class=\"nt\">&lt;button<\/span> <span class=\"err\">@<\/span><span class=\"na\">onclick=<\/span><span class=\"s\">\"getBooks\"<\/span><span class=\"nt\">&gt;<\/span>Get Books!<span class=\"nt\">&lt;\/button&gt;<\/span>\r\n    <span class=\"nt\">&lt;h3&gt;<\/span>BookLists (@date)<span class=\"nt\">&lt;\/h3&gt;<\/span>\r\n    <span class=\"nt\">&lt;ul&gt;<\/span>\r\n        @foreach(var book in books){<span class=\"nt\">&lt;li<\/span> <span class=\"err\">@<\/span><span class=\"na\">key=<\/span><span class=\"s\">\"book\"<\/span><span class=\"nt\">&gt;<\/span>@book<span class=\"nt\">&lt;\/li&gt;<\/span>}\r\n    <span class=\"nt\">&lt;\/ul&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@inject AppState state;\r\n@implements IDisposable;\r\n\r\n@code{\r\n    protected override void OnInitialized(){state.OnChange+=StateHasChanged;}\r\n    public void Dispose(){state.OnChange-=StateHasChanged;}\r\n\r\n    string[] books={};\r\n    DateTime? date=null;\r\n\r\n    void getBooks(){\r\n        books=state.books;\r\n        date=state.date;\r\n    }\r\n}\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;div<\/span> <span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;div&gt;&lt;textarea<\/span> <span class=\"err\">@<\/span><span class=\"na\">bind=<\/span><span class=\"s\">\"bookList\"<\/span> <span class=\"na\">id=<\/span><span class=\"s\">\"bookList\"<\/span><span class=\"nt\">&gt;&lt;\/textarea&gt;&lt;\/div&gt;<\/span>\r\n    <span class=\"nt\">&lt;button<\/span> <span class=\"err\">@<\/span><span class=\"na\">onclick=<\/span><span class=\"s\">\"setBooks\"<\/span><span class=\"nt\">&gt;<\/span>Set Books!<span class=\"nt\">&lt;\/button&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nf\">#bookList<\/span><span class=\"p\">{<\/span>\r\n        <span class=\"nl\">height<\/span><span class=\"p\">:<\/span> <span class=\"m\">300px<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"nl\">width<\/span><span class=\"p\">:<\/span> <span class=\"m\">300px<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n@inject IJSRuntime js;\r\n@inject AppState state;\r\n\r\n@code{\r\n    string bookList=\"\";\r\n\r\n    public void setBooks(){\r\n        state.setBooks(Array.FindAll(bookList.Replace(\"\\r\\n\",\"\\n\").Split(new[]{'\\n','\\r'}),s=&gt;s!=\"\"));\r\n        state.setDate(DateTime.Now);\r\n        js.InvokeVoidAsync(\"alert\",\"setBooks!\");\r\n    }\r\n}\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"k\">using<\/span> <span class=\"nn\">System<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"k\">public<\/span> <span class=\"k\">class<\/span> <span class=\"nc\">AppState<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"k\">public<\/span> <span class=\"kt\">string<\/span><span class=\"p\">[]<\/span> <span class=\"n\">books<\/span><span class=\"p\">{<\/span><span class=\"k\">get<\/span><span class=\"p\">;<\/span><span class=\"k\">private<\/span> <span class=\"k\">set<\/span><span class=\"p\">;}=<\/span><span class=\"k\">new<\/span> <span class=\"kt\">string<\/span><span class=\"p\">[]{};<\/span>\r\n    <span class=\"k\">public<\/span> <span class=\"n\">DateTime<\/span><span class=\"p\">?<\/span> <span class=\"n\">date<\/span><span class=\"p\">{<\/span><span class=\"k\">get<\/span><span class=\"p\">;<\/span><span class=\"k\">private<\/span> <span class=\"k\">set<\/span><span class=\"p\">;}=<\/span><span class=\"k\">null<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"k\">public<\/span> <span class=\"k\">void<\/span> <span class=\"nf\">setBooks<\/span><span class=\"p\">(<\/span><span class=\"kt\">string<\/span><span class=\"p\">[]<\/span> <span class=\"n\">books<\/span><span class=\"p\">){<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"n\">books<\/span><span class=\"p\">=<\/span><span class=\"n\">books<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"nf\">NotifyStateChanged<\/span><span class=\"p\">();<\/span>\r\n    <span class=\"p\">}<\/span>\r\n    <span class=\"k\">public<\/span> <span class=\"k\">void<\/span> <span class=\"nf\">setDate<\/span><span class=\"p\">(<\/span><span class=\"n\">DateTime<\/span> <span class=\"n\">date<\/span><span class=\"p\">){<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"n\">date<\/span><span class=\"p\">=<\/span><span class=\"n\">date<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"nf\">NotifyStateChanged<\/span><span class=\"p\">();<\/span>\r\n    <span class=\"p\">}<\/span>\r\n\r\n    <span class=\"k\">public<\/span> <span class=\"k\">event<\/span> <span class=\"n\">Action<\/span> <span class=\"n\">OnChange<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"k\">private<\/span> <span class=\"k\">void<\/span> <span class=\"nf\">NotifyStateChanged<\/span><span class=\"p\">()=&gt;<\/span><span class=\"n\">OnChange<\/span><span class=\"p\">?.<\/span><span class=\"nf\">Invoke<\/span><span class=\"p\">();<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;BooksInput&gt;&lt;\/BooksInput&gt;\r\n    &lt;button (click)=\"getBooks()\"&gt;Get Books!&lt;\/button&gt;\r\n    &lt;h3&gt;BookLists ({{date}})&lt;\/h3&gt;\r\n    &lt;ul&gt;\r\n        &lt;li *ngFor=\"let book of books\"&gt;{{book}}&lt;\/li&gt;\r\n    &lt;\/ul&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">StoreService<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">..\/..\/store.service<\/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=\"s2\">StateContainer<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">StateContainerComponent<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"kd\">constructor<\/span><span class=\"p\">(<\/span>\r\n        <span class=\"k\">private<\/span> <span class=\"nx\">store<\/span><span class=\"p\">:<\/span><span class=\"nx\">StoreService<\/span>\r\n    <span class=\"p\">){};<\/span>\r\n    <span class=\"nl\">books<\/span><span class=\"p\">:<\/span><span class=\"kr\">string<\/span><span class=\"p\">[]<\/span><span class=\"o\">=<\/span><span class=\"p\">[];<\/span>\r\n    <span class=\"nl\">date<\/span><span class=\"p\">:<\/span><span class=\"nb\">Date<\/span><span class=\"o\">=<\/span><span class=\"kc\">null<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"nx\">getBooks<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">books<\/span><span class=\"o\">=<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">store<\/span><span class=\"p\">.<\/span><span class=\"nx\">books<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">date<\/span><span class=\"o\">=<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">store<\/span><span class=\"p\">.<\/span><span class=\"nx\">date<\/span><span class=\"p\">;<\/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=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;div&gt;&lt;textarea [(ngModel)]=\"bookList\" id=\"bookList\"&gt;&lt;\/textarea&gt;&lt;\/div&gt;\r\n    &lt;button (click)=\"setBooks()\"&gt;Set Books!&lt;\/button&gt;\r\n&lt;\/div&gt;\r\n\r\n&lt;style&gt;\r\n#bookList{\r\n    height: 300px;\r\n    width: 300px;\r\n}\r\n&lt;\/style&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">StoreService<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">..\/..\/store.service<\/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=\"s2\">BooksInput<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">BooksInputComponent<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"kd\">constructor<\/span><span class=\"p\">(<\/span>\r\n        <span class=\"k\">private<\/span> <span class=\"nx\">store<\/span><span class=\"p\">:<\/span><span class=\"nx\">StoreService<\/span>\r\n    <span class=\"p\">){}<\/span>\r\n    <span class=\"nx\">bookList<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\u305f\u306e\u3057\u3044\u3055\u3093\u3059\u3046\r\n\u305f\u306e\u3057\u3044\u3053\u304f\u3054\r\n\u305f\u306e\u3057\u3044\u3069\u3046\u3068\u304f\r\n\u304b\u3050\u3084\u3072\u3081\r\n\u30b7\u30f3\u30c7\u30ec\u30e9\r\n\u3046\u3089\u3057\u307e\u305f\u308d\u3046\r\n\u304b\u3061\u304b\u3061\u3084\u307e`<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"k\">public<\/span> <span class=\"nx\">setBooks<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">store<\/span><span class=\"p\">.<\/span><span class=\"nx\">books<\/span><span class=\"o\">=<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">bookList<\/span><span class=\"p\">.<\/span><span class=\"nx\">split<\/span><span class=\"p\">(<\/span><span class=\"sr\">\/<\/span><span class=\"se\">\\r<\/span><span class=\"sr\">|<\/span><span class=\"se\">\\n<\/span><span class=\"sr\">|<\/span><span class=\"se\">\\r\\n<\/span><span class=\"sr\">\/<\/span><span class=\"p\">).<\/span><span class=\"nx\">filter<\/span><span class=\"p\">(<\/span><span class=\"nx\">s<\/span><span class=\"o\">=&gt;<\/span><span class=\"nx\">s<\/span><span class=\"o\">!=<\/span><span class=\"dl\">\"\"<\/span><span class=\"p\">);<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">store<\/span><span class=\"p\">.<\/span><span class=\"nx\">date<\/span><span class=\"o\">=<\/span><span class=\"k\">new<\/span> <span class=\"nb\">Date<\/span><span class=\"p\">();<\/span>\r\n        <span class=\"nx\">alert<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">setBooks!<\/span><span class=\"dl\">\"<\/span><span class=\"p\">);<\/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=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Injectable<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@angular\/core<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Injectable<\/span><span class=\"p\">({<\/span>\r\n    <span class=\"na\">providedIn<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">root<\/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\">StoreService<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">books<\/span><span class=\"p\">:<\/span><span class=\"kr\">string<\/span><span class=\"p\">[]<\/span><span class=\"o\">=<\/span><span class=\"p\">[];<\/span>\r\n    <span class=\"nl\">date<\/span><span class=\"p\">:<\/span><span class=\"nb\">Date<\/span><span class=\"o\">=<\/span><span class=\"kc\">null<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>18. \u8bfb\u53d6JSON\u6587\u4ef6<\/h2>\n<p>\u5728Vue.js\/Blazor\/Angular\u4e2d\uff0c\u53ef\u4ee5\u8bfb\u53d6\u5e76\u663e\u793aJSON\u6587\u4ef6\u3002(\u7531\u4e8e\u662f\u5ba2\u6237\u7aef\u7aef\uff0c\u65e0\u6cd5\u8fdb\u884c\u5199\u5165\u64cd\u4f5c)<\/p>\n<p>\u5728\u8fd9\u91cc\u5c06\u52a0\u8f7d\u4ee5\u4e0bJSON\u6587\u4ef6\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"p\">[<\/span>\r\n    <span class=\"s2\">\"\u5927\u5263\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s2\">\"\u592a\u5200\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s2\">\"\u7247\u624b\u5263\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s2\">\"\u53cc\u5263\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s2\">\"\u30cf\u30f3\u30de\u30fc\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s2\">\"\u72e9\u731f\u7b1b\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s2\">\"\u30e9\u30f3\u30b9\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s2\">\"\u30ac\u30f3\u30e9\u30f3\u30b9\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s2\">\"\u30b9\u30e9\u30c3\u30b7\u30e5\u30a2\u30c3\u30af\u30b9\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s2\">\"\u30c1\u30e3\u30fc\u30b8\u30a2\u30c3\u30af\u30b9\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s2\">\"\u64cd\u866b\u68cd\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s2\">\"\u30e9\u30a4\u30c8\u30dc\u30a6\u30ac\u30f3\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s2\">\"\u30d8\u30d3\u30a3\u30dc\u30a6\u30ac\u30f3\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s2\">\"\u5f13\"<\/span>\r\n<span class=\"p\">]<\/span>\r\n<\/code><\/pre>\n<h3>Vue.js \u662f\u4e00\u4e2a\u6d41\u884c\u7684JavaScript\u524d\u7aef\u6846\u67b6\u3002<\/h3>\n<p>\u4f7f\u7528 require \u51fd\u6570\u5c06 JSON \u6587\u4ef6\u653e\u7f6e\u5728 \/src\/assets\/ \u76ee\u5f55\u4e0b\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h3&gt;<\/span>Read JSON<span class=\"nt\">&lt;\/h3&gt;<\/span>\r\n    <span class=\"nt\">&lt;ul&gt;<\/span>\r\n        <span class=\"nt\">&lt;li<\/span> <span class=\"na\">v-for=<\/span><span class=\"s\">\"value in list\"<\/span> <span class=\"na\">:key=<\/span><span class=\"s\">\"value\"<\/span><span class=\"nt\">&gt;<\/span><span class=\"si\">{{<\/span><span class=\"nx\">value<\/span><span class=\"si\">}}<\/span><span class=\"nt\">&lt;\/li&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/ul&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ReadJSON<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">list<\/span><span class=\"p\">:<\/span><span class=\"nx\">string<\/span><span class=\"p\">[]<\/span><span class=\"o\">=<\/span><span class=\"p\">[];<\/span>\r\n\r\n    <span class=\"nx\">mounted<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">list<\/span><span class=\"o\">=<\/span><span class=\"nx\">require<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">@\/assets\/weapons.json<\/span><span class=\"dl\">\"<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u853d\u82a6\u9614\u5c14<\/h3>\n<p>\u4f7f\u7528 HttpClient.GetJsonAsync \u65b9\u6cd5\uff0c\u5728\/wwwroot\/ \u76ee\u5f55\u4e0b\u653e\u7f6e JSON \u6587\u4ef6\u3002<\/p>\n<p>\u5c06 JSON \u6587\u4ef6\u653e\u7f6e\u5728 \/wwwroot\/ \u76ee\u5f55\u4e0b\uff0c\u4f7f\u7528 HttpClient.GetJsonAsync \u65b9\u6cd5\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/ReadJSON\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h3&gt;<\/span>Read JSON<span class=\"nt\">&lt;\/h3&gt;<\/span>\r\n    <span class=\"nt\">&lt;ul&gt;<\/span>\r\n        @foreach(var value in list){<span class=\"nt\">&lt;li<\/span> <span class=\"err\">@<\/span><span class=\"na\">key=<\/span><span class=\"s\">\"value\"<\/span><span class=\"nt\">&gt;<\/span>@value<span class=\"nt\">&lt;\/li&gt;<\/span>}\r\n    <span class=\"nt\">&lt;\/ul&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@inject HttpClient http;\r\n\r\n@code{\r\n    string[] list={};\r\n\r\n    protected override async Task OnAfterRenderAsync(bool firstRender){\r\n        if(!firstRender) return;\r\n        list=await http.GetJsonAsync<span class=\"nt\">&lt;string<\/span><span class=\"err\">[]<\/span><span class=\"nt\">&gt;<\/span>(\"Assets\/weapons.json?0\");\r\n        StateHasChanged();\r\n    }\r\n}\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<p>\u4f7f\u7528HttpClient\u6a21\u5757\u7684get\u65b9\u6cd5\u3002<br \/>\n\u9700\u8981\u5728add.module.ts\u4e2d\u6dfb\u52a0\u670d\u52a1\u624d\u80fd\u4f7f\u7528\u3002<br \/>\nJSON\u6587\u4ef6\u7684\u8def\u5f84\u5fc5\u987b\u4e3a\/src\/assets\/\u4e0b\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h3&gt;Read JSON&lt;\/h3&gt;\r\n    &lt;ul&gt;\r\n        &lt;li *ngFor=\"let value of list\"&gt;{{value}}&lt;\/li&gt;\r\n    &lt;\/ul&gt;\r\n&lt;\/div&gt;`<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">OnInit<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@angular\/core<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">HttpClient<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@angular\/common\/http<\/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=\"s2\">ReadJSON<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ReadJSONComponent<\/span> <span class=\"k\">implements<\/span> <span class=\"nx\">OnInit<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"kd\">constructor<\/span><span class=\"p\">(<\/span>\r\n        <span class=\"k\">private<\/span> <span class=\"nx\">http<\/span><span class=\"p\">:<\/span><span class=\"nx\">HttpClient<\/span>\r\n    <span class=\"p\">){}<\/span>\r\n    <span class=\"nl\">list<\/span><span class=\"p\">:<\/span><span class=\"kr\">string<\/span><span class=\"p\">[]<\/span><span class=\"o\">=<\/span><span class=\"p\">[];<\/span>\r\n\r\n    <span class=\"k\">async<\/span> <span class=\"nx\">ngOnInit<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">list<\/span><span class=\"o\">=<\/span><span class=\"k\">await<\/span> <span class=\"k\">new<\/span> <span class=\"nb\">Promise<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"o\">=&gt;<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">http<\/span><span class=\"p\">.<\/span><span class=\"kd\">get<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">.\/assets\/weapons.json?0<\/span><span class=\"dl\">\"<\/span><span class=\"p\">).<\/span><span class=\"nx\">subscribe<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"p\">));<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>19. \u6587\u672c\u6587\u4ef6\u7684\u8bfb\u53d6<\/h2>\n<h3>Vue.js (\u4e2d\u6587\u9009\u9879\uff1aVue.js )<\/h3>\n<p>\u6211\u4eec\u65e0\u6cd5\u4ec5\u4f7f\u7528Vue.js\u6765\u8bfb\u53d6\u7eaf\u6587\u672c\u6587\u4ef6\u3002\u5efa\u8bae\u4f7f\u7528Vue.js\u5b98\u65b9\u7684axios\u6765\u8fdb\u884c\u8bfb\u53d6\u3002\u53ef\u4ee5\u901a\u8fc7yarn\u6216npm\u5c06\u5176\u6dfb\u52a0\u5230\u9879\u76ee\u4e2d\u3002<\/p>\n<p>\u6b64\u5916\uff0c\u4f7f\u7528\u8fd9\u79cd\u65b9\u6cd5\u4e5f\u53ef\u4ee5\u52a0\u8f7dJSON\uff0c\u4f46\u9700\u8981\u6ce8\u610f\u7684\u662f\uff0c\u5bf9\u6587\u4ef6\u7684\u5904\u7406\u6709\u4e9b\u4e0d\u540c\u3002<\/p>\n<div>\n<div class=\"post-table\">\u30e1\u30bd\u30c3\u30c9\u30d1\u30b9\u5099\u8003axios.get\/public\/\u500b\u5225\u306e\u9759\u7684\u30d5\u30a1\u30a4\u30eb\u3068\u3057\u3066\u6271\u3046require\/src\/assets\u30d3\u30eb\u30c9\u6642js\u30d5\u30a1\u30a4\u30eb\u3068\u3068\u3082\u306b\u7d50\u5408\u3055\u308c\u308b<\/div>\n<\/div>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h3&gt;<\/span>Read Text<span class=\"nt\">&lt;\/h3&gt;<\/span>\r\n    <span class=\"nt\">&lt;pre&gt;<\/span><span class=\"si\">{{<\/span><span class=\"nx\">text<\/span><span class=\"si\">}}<\/span><span class=\"nt\">&lt;\/pre&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">axios<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">axios<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ReadText<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">text<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"\"<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"k\">async<\/span> <span class=\"nx\">mounted<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">text<\/span><span class=\"o\">=<\/span><span class=\"k\">await<\/span> <span class=\"nx\">axios<\/span><span class=\"p\">.<\/span><span class=\"kd\">get<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">.\/kimigayo.txt?0<\/span><span class=\"dl\">\"<\/span><span class=\"p\">).<\/span><span class=\"nx\">then<\/span><span class=\"p\">(<\/span><span class=\"nx\">v<\/span><span class=\"o\">=&gt;<\/span><span class=\"nx\">v<\/span><span class=\"p\">.<\/span><span class=\"nx\">data<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>Blazor (\u5e03\u62c9\u6cfd)<\/h3>\n<p>\u4f7f\u7528HttpClient.GetStringAsync\u8fdb\u884c\u8bfb\u53d6\uff0c\u5c31\u50cf\u4f7f\u7528JSON\u4e00\u6837\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/ReadText\"\r\n\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h3&gt;<\/span>Read Text<span class=\"nt\">&lt;\/h3&gt;<\/span>\r\n    <span class=\"nt\">&lt;pre&gt;<\/span>@text<span class=\"nt\">&lt;\/pre&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n@inject HttpClient http;\r\n\r\n@code{\r\n    string text=\"\";\r\n\r\n    protected override async Task OnAfterRenderAsync(bool firstRender){\r\n        if(!firstRender) return;\r\n        text=await http.GetStringAsync(\".\/kimigayo.txt?0\");\r\n        StateHasChanged();\r\n    }\r\n}\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<p>\u4f60\u53ef\u4ee5\u50cf\u4f7f\u7528JSON\u4e00\u6837\u4f7f\u7528HttpClient.get\u3002<br \/>\n\u8981\u8bfb\u53d6\u6587\u672c\u6587\u4ef6\uff0c\u9700\u8981\u5728\u53c2\u6570\u4e2d\u52a0\u5165{ responseType: &#8220;text&#8221; }\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h3&gt;Read Text&lt;\/h3&gt;\r\n    &lt;pre&gt;{{text}}&lt;\/pre&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">OnInit<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@angular\/core<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">HttpClient<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@angular\/common\/http<\/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=\"s2\">ReadText<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">ReadTextComponent<\/span> <span class=\"k\">implements<\/span> <span class=\"nx\">OnInit<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"kd\">constructor<\/span><span class=\"p\">(<\/span>\r\n        <span class=\"k\">private<\/span> <span class=\"nx\">http<\/span><span class=\"p\">:<\/span><span class=\"nx\">HttpClient<\/span>\r\n    <span class=\"p\">){}<\/span>\r\n    <span class=\"nx\">text<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"\"<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"k\">async<\/span> <span class=\"nx\">ngOnInit<\/span><span class=\"p\">(){<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">text<\/span><span class=\"o\">=<\/span><span class=\"k\">await<\/span> <span class=\"k\">new<\/span> <span class=\"nb\">Promise<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"o\">=&gt;<\/span><span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">http<\/span><span class=\"p\">.<\/span><span class=\"kd\">get<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">.\/assets\/kimigayo.txt?0<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,{<\/span><span class=\"na\">responseType<\/span><span class=\"p\">:<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">text<\/span><span class=\"dl\">\"<\/span><span class=\"p\">}).<\/span><span class=\"nx\">subscribe<\/span><span class=\"p\">(<\/span><span class=\"nx\">res<\/span><span class=\"p\">));<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>20. HTML\u8f93\u51fa<\/h2>\n<p>\u5728Vue.js\/Blazor\/Angular\u4e2d\uff0c\u60a8\u53ef\u4ee5\u50cfelement.innerHTML\u4e00\u6837\u5c06HTML\u5199\u5165\u5230HTML\u4e2d\u3002<\/p>\n<h3>Vue.js\u662f\u4e00\u4e2a\u6d41\u884c\u7684JavaScript\u524d\u7aef\u6846\u67b6\u3002<\/h3>\n<p>\u5c06\u503c\u7ed1\u5b9a\u5230 v-html \u5c5e\u6027\u4e0a\u3002<br \/>\n\u4e0d\u5141\u8bb8\u4f7f\u7528 script \u5143\u7d20\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;h3&gt;<\/span>Inner HTML<span class=\"nt\">&lt;\/h3&gt;<\/span>\r\n    <span class=\"nt\">&lt;textarea<\/span> <span class=\"na\">v-model=<\/span><span class=\"s\">\"txt\"<\/span> <span class=\"na\">style=<\/span><span class=\"s\">\"height:300px;width:300px;\"<\/span><span class=\"nt\">&gt;&lt;\/textarea&gt;<\/span>\r\n    <span class=\"nt\">&lt;div<\/span> <span class=\"na\">v-html=<\/span><span class=\"s\">\"txt\"<\/span><span class=\"nt\">&gt;&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"p\">@<\/span><span class=\"nd\">Component<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">InnerHTML<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">txt<\/span><span class=\"o\">=<\/span>\r\n<span class=\"s2\">`&lt;h1&gt;TEST TITLE&lt;\/h1&gt;\r\n\r\n&lt;span style=color:#009900&gt;\r\n&lt;u&gt;Say&lt;\/u&gt; &lt;i&gt;Hello!&lt;\/i&gt;\r\n&lt;\/span&gt;`<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>Blazor = \u5e03\u96f7\u6cfd<\/h3>\n<p>\u901a\u8fc7\u5c06\u5b57\u7b26\u4e32\u8f6c\u6362\u4e3aMarkupString\u7c7b\u578b\u5e76\u5c06\u5176\u8f93\u51fa\u5230\u4efb\u610f\u4f4d\u7f6e\uff0c\u53ef\u4ee5\u8f93\u51faHTML\u3002<br \/>\n\u65e0\u6cd5\u4f7f\u7528script\u5143\u7d20\u3002<\/p>\n<pre class=\"post-pre\"><code>@page \"\/InnerHTML\"\r\n\r\n&lt;div&gt;\r\n    &lt;h3&gt;Inner HTML&lt;\/h3&gt;\r\n    &lt;textarea @bind-value=\"txt\" @bind-value:event=\"oninput\" style=\"height:300px;width:300px;\"&gt;&lt;\/textarea&gt;\r\n    &lt;div&gt;@((MarkupString)txt)&lt;\/div&gt;\r\n&lt;\/div&gt;\r\n\r\n@code{\r\n    string txt=\r\n@\"&lt;h1&gt;TEST TITLE&lt;\/h1&gt;\r\n\r\n&lt;span style=color:#990099&gt;\r\n&lt;u&gt;Say&lt;\/u&gt; &lt;i&gt;Hello!&lt;\/i&gt;\r\n&lt;\/span&gt;\";\r\n}\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<p>\u628a\u503c\u7ed1\u5b9a\u5230[innerHTML]\u5c5e\u6027\u4e2d\u3002\u9664\u4e86script\u6807\u7b7e\u5916\uff0c\u8fd8\u4e0d\u80fd\u4f7f\u7528style\u6807\u7b7e\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;div&gt;\r\n    &lt;h3&gt;Inner HTML&lt;\/h3&gt;\r\n    &lt;textarea [(ngModel)]=\"txt\" style=\"height:300px;width:300px;\"&gt;&lt;\/textarea&gt;\r\n    &lt;div [innerHTML]=\"txt\"&gt;&lt;\/div&gt;\r\n&lt;\/div&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">InnerHTML<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">InnerHTMLComponent<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nx\">txt<\/span><span class=\"o\">=<\/span>\r\n<span class=\"s2\">`&lt;h1&gt;TEST TITLE&lt;\/h1&gt;\r\n\r\n&lt;font color=\"#990000\"&gt;\r\n&lt;u&gt;Say&lt;\/u&gt; &lt;i&gt;Hello!&lt;\/i&gt;\r\n&lt;\/font&gt;`<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h2>\u8def\u7531\u5668 q\u00ec)<\/h2>\n<p>\u6700\u540e\uff0c\u6211\u4eec\u5c06\u5c55\u793a\u672c\u6b21\u4f7f\u7528\u7684\u8def\u7531\u5668\u793a\u4f8b\u3002<\/p>\n<h3>Vue.js\u662f\u4e00\u4e2a\u7528\u4e8e\u6784\u5efa\u7528\u6237\u754c\u9762\u7684\u6e10\u8fdb\u5f0fJavaScript\u6846\u67b6\u3002<\/h3>\n<p>\u6bcf\u5f53\u9875\u9762\u589e\u52a0\u65f6\uff0c\u90fd\u9700\u8981\u5728\/src\/router.index.ts\u4e2d\u6dfb\u52a0\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"nx\">Vue<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">VueRouter<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-router<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">Index<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@\/views\/Index.vue<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">PageA<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@\/views\/PageA.vue<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">PageB<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@\/views\/PageB.vue<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"nx\">Vue<\/span><span class=\"p\">.<\/span><span class=\"nx\">use<\/span><span class=\"p\">(<\/span><span class=\"nx\">VueRouter<\/span><span class=\"p\">);<\/span>\r\n\r\n<span class=\"kd\">const<\/span> <span class=\"nx\">routes<\/span><span class=\"o\">=<\/span><span class=\"p\">[<\/span>\r\n    <span class=\"p\">{<\/span><span class=\"na\">path<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">\/<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span> <span class=\"na\">name<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">Index<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span> <span class=\"na\">component<\/span><span class=\"p\">:<\/span> <span class=\"nx\">Index<\/span><span class=\"p\">},<\/span>\r\n    <span class=\"p\">{<\/span><span class=\"na\">path<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">\/PageA<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span> <span class=\"na\">name<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">PageA<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span> <span class=\"na\">component<\/span><span class=\"p\">:<\/span> <span class=\"nx\">PageA<\/span><span class=\"p\">},<\/span>\r\n    <span class=\"p\">{<\/span><span class=\"na\">path<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">\/PageB<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span> <span class=\"na\">name<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">PageB<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span> <span class=\"na\">component<\/span><span class=\"p\">:<\/span> <span class=\"nx\">PageB<\/span><span class=\"p\">}<\/span>\r\n<span class=\"p\">];<\/span>\r\n\r\n<span class=\"kd\">const<\/span> <span class=\"nx\">router<\/span><span class=\"o\">=<\/span><span class=\"k\">new<\/span> <span class=\"nx\">VueRouter<\/span><span class=\"p\">({<\/span>\r\n    <span class=\"na\">mode<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">history<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">base<\/span><span class=\"p\">:<\/span> <span class=\"nx\">process<\/span><span class=\"p\">.<\/span><span class=\"nx\">env<\/span><span class=\"p\">.<\/span><span class=\"nx\">BASE_URL<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nx\">routes<\/span>\r\n<span class=\"p\">});<\/span>\r\n\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"nx\">router<\/span><span class=\"p\">;<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;main<\/span> <span class=\"na\">style=<\/span><span class=\"s\">display:flex<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;NavMenu<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n    <span class=\"nt\">&lt;div<\/span> <span class=\"na\">class=<\/span><span class=\"s\">v-hr<\/span><span class=\"nt\">&gt;&lt;\/div&gt;<\/span>\r\n    <span class=\"nt\">&lt;router-view\/&gt;<\/span>\r\n<span class=\"nt\">&lt;\/main&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">style<\/span> <span class=\"na\">scoped<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nc\">.v-hr<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">margin<\/span><span class=\"p\">:<\/span> <span class=\"m\">0<\/span> <span class=\"m\">10px<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">border-right<\/span><span class=\"p\">:<\/span> <span class=\"m\">5px<\/span> <span class=\"nb\">solid<\/span> <span class=\"m\">#CCC<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">height<\/span><span class=\"p\">:<\/span> <span class=\"m\">100vh<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">script<\/span> <span class=\"na\">lang:ts<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Component<\/span><span class=\"p\">,<\/span><span class=\"nx\">Vue<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vue-property-decorator<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">NavMenu<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@\/components\/NavMenu.vue<\/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\">components<\/span><span class=\"p\">:{<\/span>\r\n        <span class=\"nx\">NavMenu<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">App<\/span> <span class=\"kd\">extends<\/span> <span class=\"nx\">Vue<\/span><span class=\"p\">{}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">script<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;nav&gt;<\/span>\r\n    <span class=\"nt\">&lt;ol<\/span> <span class=\"na\">type=<\/span><span class=\"s\">\"1\"<\/span> <span class=\"na\">start=<\/span><span class=\"s\">\"0\"<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"nt\">&lt;li&gt;&lt;router-link<\/span> <span class=\"na\">to=<\/span><span class=\"s\">\"\/\"<\/span><span class=\"nt\">&gt;<\/span>index<span class=\"nt\">&lt;\/router-link&gt;&lt;\/li&gt;<\/span>\r\n        <span class=\"nt\">&lt;li&gt;&lt;router-link<\/span> <span class=\"na\">to=<\/span><span class=\"s\">\"\/PageA\"<\/span><span class=\"nt\">&gt;<\/span>PageA<span class=\"nt\">&lt;\/router-link&gt;&lt;\/li&gt;<\/span>\r\n        <span class=\"nt\">&lt;li&gt;&lt;router-link<\/span> <span class=\"na\">to=<\/span><span class=\"s\">\"\/PageB\"<\/span><span class=\"nt\">&gt;<\/span>PageB<span class=\"nt\">&lt;\/router-link&gt;&lt;\/li&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/ol&gt;<\/span>\r\n<span class=\"nt\">&lt;\/nav&gt;<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">template<\/span><span class=\"nt\">&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">style<\/span> <span class=\"na\">scoped<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nc\">.router-link-exact-active<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">color<\/span><span class=\"p\">:<\/span> <span class=\"m\">#FF0000<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">font-weight<\/span><span class=\"p\">:<\/span> <span class=\"nb\">bold<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>Blazor<\/h3>\n<pre class=\"post-pre\"><code>@inherits LayoutComponentBase\r\n\r\n<span class=\"nt\">&lt;main<\/span> <span class=\"na\">style=<\/span><span class=\"s\">display:flex<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;NavMenu<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n    <span class=\"nt\">&lt;div<\/span> <span class=\"na\">class=<\/span><span class=\"s\">v-hr<\/span><span class=\"nt\">&gt;&lt;\/div&gt;<\/span>\r\n    @Body\r\n<span class=\"nt\">&lt;\/main&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nc\">.v-hr<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">margin<\/span><span class=\"p\">:<\/span> <span class=\"m\">0<\/span> <span class=\"m\">10px<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">border-right<\/span><span class=\"p\">:<\/span> <span class=\"m\">5px<\/span> <span class=\"nb\">solid<\/span> <span class=\"m\">#CCC<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">height<\/span><span class=\"p\">:<\/span> <span class=\"m\">100vh<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;div&gt;<\/span>\r\n    <span class=\"nt\">&lt;ol<\/span> <span class=\"na\">type=<\/span><span class=\"s\">\"1\"<\/span> <span class=\"na\">start=<\/span><span class=\"s\">\"0\"<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"nt\">&lt;li&gt;&lt;NavLink<\/span> <span class=\"na\">Match=<\/span><span class=\"s\">\"NavLinkMatch.All\"<\/span> <span class=\"na\">href=<\/span><span class=\"s\">\".\/\"<\/span><span class=\"nt\">&gt;<\/span>index<span class=\"nt\">&lt;\/NavLink&gt;&lt;\/li&gt;<\/span>\r\n        <span class=\"nt\">&lt;li&gt;&lt;NavLink<\/span> <span class=\"na\">Match=<\/span><span class=\"s\">\"NavLinkMatch.All\"<\/span> <span class=\"na\">href=<\/span><span class=\"s\">\".\/PageA\"<\/span><span class=\"nt\">&gt;<\/span>PageA<span class=\"nt\">&lt;\/NavLink&gt;&lt;\/li&gt;<\/span>\r\n        <span class=\"nt\">&lt;li&gt;&lt;NavLink<\/span> <span class=\"na\">Match=<\/span><span class=\"s\">\"NavLinkMatch.All\"<\/span> <span class=\"na\">href=<\/span><span class=\"s\">\".\/PageB\"<\/span><span class=\"nt\">&gt;<\/span>PageB<span class=\"nt\">&lt;\/NavLink&gt;&lt;\/li&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/ol&gt;<\/span>\r\n<span class=\"nt\">&lt;\/div&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">nav<\/span> <span class=\"nc\">.active<\/span><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">color<\/span><span class=\"p\">:<\/span> <span class=\"m\">#FF0000<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">font-weight<\/span><span class=\"p\">:<\/span> <span class=\"nb\">bold<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n<span class=\"nt\">&lt;\/<\/span><span class=\"k\">style<\/span><span class=\"nt\">&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u89d2\u5ea6<\/h3>\n<p>\u6bcf\u589e\u52a0\u4e00\u9875\uff0c\u90fd\u9700\u8981\u5728\/src\/app\/app-routing.module.ts\u4e2d\u8fdb\u884c\u6dfb\u52a0\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">NgModule<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@angular\/core<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">Routes<\/span><span class=\"p\">,<\/span> <span class=\"nx\">RouterModule<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@angular\/router<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">IndexComponent<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">.\/pages\/Index\/Index.component<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">PageAComponent<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">.\/pages\/PageA\/PageA.component<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">PageBComponent<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">.\/pages\/PageB\/PageB.component<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"kd\">const<\/span> <span class=\"nx\">routes<\/span><span class=\"p\">:<\/span> <span class=\"nx\">Routes<\/span><span class=\"o\">=<\/span><span class=\"p\">[<\/span>\r\n    <span class=\"p\">{<\/span><span class=\"na\">path<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"\"<\/span><span class=\"p\">,<\/span> <span class=\"na\">component<\/span><span class=\"p\">:<\/span> <span class=\"nx\">IndexComponent<\/span><span class=\"p\">},<\/span>\r\n    <span class=\"p\">{<\/span><span class=\"na\">path<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">PageA<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span> <span class=\"na\">component<\/span><span class=\"p\">:<\/span> <span class=\"nx\">PageAComponent<\/span><span class=\"p\">},<\/span>\r\n    <span class=\"p\">{<\/span><span class=\"na\">path<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">PageB<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span> <span class=\"na\">component<\/span><span class=\"p\">:<\/span> <span class=\"nx\">PageBComponent<\/span><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\">RouterModule<\/span><span class=\"p\">.<\/span><span class=\"nx\">forRoot<\/span><span class=\"p\">(<\/span><span class=\"nx\">routes<\/span><span class=\"p\">)],<\/span>\r\n  <span class=\"na\">exports<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">RouterModule<\/span><span class=\"p\">]<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">AppRoutingModule<\/span> <span class=\"p\">{<\/span> <span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;main style=display:flex&gt;\r\n    &lt;NavMenu&gt;&lt;\/NavMenu&gt;\r\n    &lt;div class=v-hr&gt;&lt;\/div&gt;\r\n    &lt;router-outlet&gt;&lt;\/router-outlet&gt;\r\n&lt;\/main&gt;\r\n\r\n&lt;style&gt;\r\n.v-hr{\r\n    margin: 0 10px;\r\n    border-right: 5px solid #CCC;\r\n    height: 98vh;\r\n}\r\n&lt;\/style&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">app-root<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">template<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/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<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">template<\/span><span class=\"o\">=<\/span><span class=\"s2\">`\r\n&lt;nav&gt;\r\n    &lt;ol type=\"1\" start=\"0\"&gt;\r\n        &lt;li&gt;&lt;a routerLinkActive=\"active\" [routerLinkActiveOptions]=\"{exact:true}\" routerLink=\"\/\"&gt;index&lt;\/a&gt;&lt;\/li&gt;\r\n        &lt;li&gt;&lt;a routerLinkActive=\"active\" [routerLinkActiveOptions]=\"{exact:true}\" routerLink=\"\/PageA\"&gt;PageA&lt;\/a&gt;&lt;\/li&gt;\r\n        &lt;li&gt;&lt;a routerLinkActive=\"active\" [routerLinkActiveOptions]=\"{exact:true}\" routerLink=\"\/PageB\"&gt;PageB&lt;\/a&gt;&lt;\/li&gt;\r\n    &lt;\/ol&gt;\r\n&lt;\/nav&gt;\r\n\r\n&lt;style&gt;\r\n.active{\r\n    color: #FF0000;\r\n    font-weight: bold;\r\n}\r\n&lt;\/style&gt;\r\n`<\/span><span class=\"p\">;<\/span>\r\n\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=\"s2\">@angular\/core<\/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=\"s2\">NavMenu<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"na\">templateUrl<\/span><span class=\"p\">:<\/span> <span class=\"nx\">template<\/span>\r\n<span class=\"p\">})<\/span>\r\n<span class=\"k\">export<\/span> <span class=\"kd\">class<\/span> <span class=\"nx\">NavMenuComponent<\/span><span class=\"p\">{}<\/span>\r\n<\/code><\/pre>\n<h1>\u603b\u7ed3<\/h1>\n<p>\u6211\u603b\u7ed3\u4e86\u4e00\u4e0bVue.js\u548cBlazor\uff08+ Angular\uff09\u7684\u8bed\u6cd5\u6bd4\u8f83\u3002\u867d\u7136\u5728\u6837\u5f0f\u89c4\u8303\u7b49\u65b9\u9762\u6709\u4e9b\u65e0\u6cd5\u6539\u53d8\u7684\u90e8\u5206\uff0c\u4f46\u5927\u90e8\u5206\u60c5\u51b5\u4e0b\u90fd\u53ef\u4ee5\u4ee5\u51e0\u4e4e\u76f8\u540c\u7684\u65b9\u5f0f\u7f16\u5199\u3002\u6211\u8fd8\u89c9\u5f97\u5728\u901f\u5ea6\u65b9\u9762\u8fd8\u6709\u4e9b\u56f0\u96be\uff0c\u4f46\u6211\u5e0c\u671b\u672a\u6765\u7684Blazor\u80fd\u6709\u6240\u671f\u5f85\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u9488\u5bf9\u5177\u6709\u4e00\u5b9a\u7a0b\u5ea6\u7684Vue.js\/Blazor\/Angular\u8bed\u6cd5\u7684\u65b9\u6cd5\uff0c\u6211\u4eec\u603b\u7ed3\u4e86\u5b9e\u73b0\u7c7b\u4f3c\u529f\u80fd\u7684\u65b9\u5f0f\u3002\u6e90\u4ee3\u7801\u8bf7 [&hellip;]<\/p>\n","protected":false},"author":11,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-39623","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>Vue.js\/Blazor\/Angular\u7684\u8bed\u6cd5\u6bd4\u8f83\u793a\u4f8b\u96c6\u5408 - 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\/vue-js-blazor-angular\u7684\u8bed\u6cd5\u6bd4\u8f83\u793a\u4f8b\u96c6\u5408\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Vue.js\/Blazor\/Angular\u7684\u8bed\u6cd5\u6bd4\u8f83\u793a\u4f8b\u96c6\u5408\" \/>\n<meta property=\"og:description\" content=\"\u9488\u5bf9\u5177\u6709\u4e00\u5b9a\u7a0b\u5ea6\u7684Vue.js\/Blazor\/Angular\u8bed\u6cd5\u7684\u65b9\u6cd5\uff0c\u6211\u4eec\u603b\u7ed3\u4e86\u5b9e\u73b0\u7c7b\u4f3c\u529f\u80fd\u7684\u65b9\u5f0f\u3002\u6e90\u4ee3\u7801\u8bf7 [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular\u7684\u8bed\u6cd5\u6bd4\u8f83\u793a\u4f8b\u96c6\u5408\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-08-11T11:31:40+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-29T03:58:51+00:00\" \/>\n<meta name=\"author\" content=\"\u65b0, \u97f5\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u65b0, \u97f5\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"26 \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\/vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88\/\",\"name\":\"Vue.js\/Blazor\/Angular\u7684\u8bed\u6cd5\u6bd4\u8f83\u793a\u4f8b\u96c6\u5408 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-08-11T11:31:40+00:00\",\"dateModified\":\"2024-04-29T03:58:51+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/4ba4019495123db3038fd0809e6959c9\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Vue.js\/Blazor\/Angular\u7684\u8bed\u6cd5\u6bd4\u8f83\u793a\u4f8b\u96c6\u5408\"}]},{\"@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\/4ba4019495123db3038fd0809e6959c9\",\"name\":\"\u65b0, \u97f5\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g\",\"caption\":\"\u65b0, \u97f5\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/yunxin\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Vue.js\/Blazor\/Angular\u7684\u8bed\u6cd5\u6bd4\u8f83\u793a\u4f8b\u96c6\u5408 - 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\/vue-js-blazor-angular\u7684\u8bed\u6cd5\u6bd4\u8f83\u793a\u4f8b\u96c6\u5408\/","og_locale":"zh_CN","og_type":"article","og_title":"Vue.js\/Blazor\/Angular\u7684\u8bed\u6cd5\u6bd4\u8f83\u793a\u4f8b\u96c6\u5408","og_description":"\u9488\u5bf9\u5177\u6709\u4e00\u5b9a\u7a0b\u5ea6\u7684Vue.js\/Blazor\/Angular\u8bed\u6cd5\u7684\u65b9\u6cd5\uff0c\u6211\u4eec\u603b\u7ed3\u4e86\u5b9e\u73b0\u7c7b\u4f3c\u529f\u80fd\u7684\u65b9\u5f0f\u3002\u6e90\u4ee3\u7801\u8bf7 [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular\u7684\u8bed\u6cd5\u6bd4\u8f83\u793a\u4f8b\u96c6\u5408\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-08-11T11:31:40+00:00","article_modified_time":"2024-04-29T03:58:51+00:00","author":"\u65b0, \u97f5","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u65b0, \u97f5","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"26 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88\/","name":"Vue.js\/Blazor\/Angular\u7684\u8bed\u6cd5\u6bd4\u8f83\u793a\u4f8b\u96c6\u5408 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-08-11T11:31:40+00:00","dateModified":"2024-04-29T03:58:51+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/4ba4019495123db3038fd0809e6959c9"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"Vue.js\/Blazor\/Angular\u7684\u8bed\u6cd5\u6bd4\u8f83\u793a\u4f8b\u96c6\u5408"}]},{"@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\/4ba4019495123db3038fd0809e6959c9","name":"\u65b0, \u97f5","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g","caption":"\u65b0, \u97f5"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/yunxin\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/vue-js-blazor-angular%e7%9a%84%e8%af%ad%e6%b3%95%e6%af%94%e8%be%83%e7%a4%ba%e4%be%8b%e9%9b%86%e5%90%88\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39623","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\/11"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=39623"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39623\/revisions"}],"predecessor-version":[{"id":85143,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39623\/revisions\/85143"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=39623"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=39623"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=39623"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}