{"id":262,"date":"2023-06-27T18:20:42","date_gmt":"2023-06-27T10:20:42","guid":{"rendered":"https:\/\/www.escook.cn\/?p=262"},"modified":"2023-09-26T21:04:27","modified_gmt":"2023-09-26T13:04:27","slug":"vue3-%e5%9f%ba%e7%a1%80-%e5%bf%ab%e9%80%9f%e4%b8%8a%e6%89%8b-%e5%b8%b8%e7%94%a8%e6%8c%87%e4%bb%a4","status":"publish","type":"post","link":"https:\/\/www.escook.cn\/index.php\/2023\/06\/27\/vue3-%e5%9f%ba%e7%a1%80-%e5%bf%ab%e9%80%9f%e4%b8%8a%e6%89%8b-%e5%b8%b8%e7%94%a8%e6%8c%87%e4%bb%a4\/","title":{"rendered":"Vue3 \u57fa\u7840 &#8211; \u5feb\u901f\u4e0a\u624b &#038; \u5e38\u7528\u6307\u4ee4 &#038; :key \u7684\u539f\u7406"},"content":{"rendered":"<blockquote>\n<p>\u7248\u6743\u5f52\u4f5c\u8005 <strong>\u00a9\u5218\u9f99\u5bbe<\/strong> \u6240\u6709\uff0c\u672c\u6587\u7ae0\u672a\u7ecf\u4f5c\u8005\u5141\u8bb8\uff0c\u7981\u6b62\u79c1\u81ea\u8f6c\u8f7d\uff01<\/p>\n<\/blockquote>\n<h2>1. \u5728 HTML \u7f51\u9875\u4e2d\u4f7f\u7528 vue3 \u76843\u4e2a\u57fa\u672c\u6b65\u9aa4<\/h2>\n<ol>\n<li>\n<p>\u901a\u8fc7 <code>script<\/code> \u6807\u7b7e\u7684 <code>src<\/code> \u5c5e\u6027\uff0c\u5728\u5f53\u524d\u7f51\u9875\u4e2d\u5168\u5c40\u5f15\u5165 vue3 \u7684\u811a\u672c\u6587\u4ef6\uff1a<\/p>\n<pre><code class=\"language-js\">&lt;script src=&quot;https:\/\/unpkg.com\/vue@3\/dist\/vue.global.js&quot;&gt;&lt;\/script&gt;<\/code><\/pre>\n<\/li>\n<li>\n<p>\u521b\u5efa vue3 \u7684\u5355\u9875\u9762\u5e94\u7528\u7a0b\u5e8f\u5b9e\u4f8b\uff1a<\/p>\n<pre><code class=\"language-js\">\/\/ 2.1 \u4ece Vue \u5bf9\u8c61\u4e2d\u89e3\u6784\u51fa createApp \u51fd\u6570\nconst { createApp } = Vue\n\n\/\/ 2.2 \u8c03\u7528 createApp \u8fd9\u4e2a\u51fd\u6570\uff0c\u5c31\u80fd\u591f\u521b\u5efa\u51fa\u4e00\u4e2a\u5355\u9875\u9762\u5e94\u7528\u7a0b\u5e8f\u7684\u5b9e\u4f8b\nconst app = createApp()\n\n\/\/ 2.3 \u8c03\u7528 app \u5b9e\u4f8b\u5bf9\u8c61\u4e0a\u7684 mount() \u51fd\u6570\uff0c\n\/\/ \u6307\u5b9a\u5355\u9875\u9762\u5e94\u7528\u7a0b\u5e8f app\uff0c\u5b9e\u9645\u8981\u63a7\u5236\u9875\u9762\u4e0a\u54ea\u4e2a\u533a\u57df\u7684\u6e32\u67d3\napp.mount('#app')<\/code><\/pre>\n<\/li>\n<li>\n<p>\u58f0\u660e vue3 \u7684\u5355\u9875\u9762\u5e94\u7528\u7a0b\u5e8f\u5b9e\u4f8b\uff0c\u5b9e\u9645\u8981\u63a7\u5236\u7684\u9875\u9762\u533a\u57df\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;!-- \u6ce8\u610f\uff1a\u5982\u679c\u5185\u5bb9\u4e3a\u7a7a\uff0c\u5219 vue3 \u4f1a\u5728\u63d0\u793a\u4e00\u4e2a\u8b66\u544a\u6d88\u606f\uff1a\n[Vue warn]: Component is missing template or render function. at &lt;App&gt; --&gt;\n&lt;div id=&quot;app&quot;&gt;&lt;\/div&gt;<\/code><\/pre>\n<\/li>\n<\/ol>\n<h2>2. \u5b9a\u4e49\u548c\u6e32\u67d3\u6570\u636e<\/h2>\n<ol>\n<li>\n<p>\u5728\u8c03\u7528 <code>createApp()<\/code> \u51fd\u6570\u65f6\uff0c\u53ef\u4ee5\u63d0\u4f9b\u4e00\u4e2a<strong>\u5bf9\u8c61<\/strong>\u4f5c\u4e3a<code>\u914d\u7f6e\u53c2\u6570<\/code>\uff0c\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({ \/*\u914d\u7f6e\u5bf9\u8c61*\/ })<\/code><\/pre>\n<\/li>\n<li>\n<p>\u5982\u679c\u60f3\u63d0\u4f9b\u8981\u6e32\u67d3\u7684\u6570\u636e\uff0c\u53ef\u4ee5\u5728\u6b65\u9aa41\u7684\u914d\u7f6e\u5bf9\u8c61\u4e2d\uff0c\u901a\u8fc7 <code>data<\/code> \u8282\u70b9\u63d0\u4f9b\u6e32\u67d3\u671f\u95f4\u8981\u4f7f\u7528\u7684\u6570\u636e\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n \/\/ 2.1 \u6ce8\u610f\uff1adata \u8282\u70b9\u662f\u4e00\u4e2a\u51fd\u6570\n data() {\n   \/\/ 2.2 \u5728 data \u51fd\u6570\u5185\u90e8\uff0creturn \u7684\u8fd9\u4e2a\u5bf9\u8c61\uff0c\u5c31\u662f\u6570\u636e\u5bf9\u8c61\uff0c\n   \/\/ \u8981\u6e32\u67d3\u7684\u6570\u636e\uff0c\u53ef\u4ee5\u76f4\u63a5\u5199\u5230\u8fd9\u4e2a\u5bf9\u8c61\u4e2d\uff0c\u4f8b\u5982 return { name: 'zs' }\n   return {}\n }\n})<\/code><\/pre>\n<\/li>\n<li>\n<p>\u5728\u6b65\u9aa42\u7684 data \u8282\u70b9\u4e2d\uff0c\u5b9a\u4e49\u4e00\u4e2a\u540d\u4e3a <code>name<\/code> \u7684\u6570\u636e\uff0c\u503c\u662f <code>liulongbin<\/code>\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n data() {\n   return {\n     name: 'liulongbin'\n   }\n }\n})<\/code><\/pre>\n<\/li>\n<li>\n<p>\u5728 vue3 \u63a7\u5236\u7684\u6a21\u677f\u7ed3\u6784\u4e2d\uff0c\u4f7f\u7528 <code>{{ \u6570\u636e\u540d }}<\/code> \u8bed\u6cd5\uff0c\u628a\u6570\u636e\u6e32\u67d3\u51fa\u6765\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div id=&quot;app&quot;&gt;\n&lt;h1&gt;\u5927\u5bb6\u597d\uff0c\u6211\u662f\uff1a{{ name }}&lt;\/h1&gt;\n&lt;\/div&gt;<\/code><\/pre>\n<\/li>\n<li>\n<p>\u62d3\u5c55\uff1a\u5f53\u6211\u4eec\u4fee\u6539 data \u8282\u70b9\u4e0b\u7684\u6570\u636e\u540e\uff0c\u5373\u53ef\u770b\u5230\u9875\u9762\u4e0a\u7684 HTML \u5185\u5bb9\u4f1a\u81ea\u52a8\u88ab\u5237\u65b0\u3002\u8fd9\u5c31\u662f vue \u7684\u5f3a\u5927\u4e4b\u5904\uff1a<strong>\u6570\u636e\u9a71\u52a8\u89c6\u56fe<\/strong>\u3002\u4fee\u6539 data \u6570\u636e\u7684\u793a\u4f8b\u4ee3\u7801\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-javascript\">app._instance.proxy.name = &#039;escook&#039;<\/code><\/pre>\n<\/li>\n<\/ol>\n<h2>3. vue3 \u4e2d\u5e38\u7528\u7684\u6e32\u67d3\u6307\u4ee4<\/h2>\n<p>\u5728 vue \u4e2d\uff0c\u6307\u4ee4\u662f\u5e26\u6709 <code>v-<\/code> \u524d\u7f00\u7684\u7279\u6b8a attribute\uff0c\u5b83\u662f vue \u63d0\u4f9b\u7684\u7279\u6b8a\u8bed\u6cd5\uff0c\u5927\u5bb6\u6709\u5fc5\u8981\u638c\u63e1 vue \u4e2d\u5e38\u7528\u6307\u4ee4\u7684\u4f7f\u7528\u3002<\/p>\n<p>\u6307\u4ee4\u80fd\u591f\u8f85\u52a9\u524d\u7aef\u7a0b\u5e8f\u5458\u9ad8\u6548\u5730\u628a\u6570\u636e\u6e32\u67d3\u4e3a HTML \u7684\u7ed3\u6784\uff0c\u800c\u7a0b\u5e8f\u5458\u4e0d\u9700\u8981\u8c03\u7528\u4efb\u4f55\u64cd\u4f5c DOM \u7684 API\u3002<\/p>\n<h3>3.0 \u5e38\u7528\u6307\u4ee4\u7684\u5206\u7c7b<\/h3>\n<ol>\n<li>\u5185\u5bb9\u6e32\u67d3\u6307\u4ee4<\/li>\n<li>\u5c5e\u6027\u7ed1\u5b9a\u6307\u4ee4<\/li>\n<li>\u53cc\u5411\u7ed1\u5b9a\u6307\u4ee4<\/li>\n<li>\u6761\u4ef6\u6e32\u67d3\u6307\u4ee4<\/li>\n<li>\u4e8b\u4ef6\u7ed1\u5b9a\u6307\u4ee4<\/li>\n<li>\u5217\u8868\u6e32\u67d3\u6307\u4ee4<\/li>\n<\/ol>\n<h3>3.1 \u5185\u5bb9\u6e32\u67d3\u6307\u4ee4<\/h3>\n<h4>1. \u63d2\u503c\u8868\u8fbe\u5f0f<\/h4>\n<p>\u63d2\u503c\u8868\u8fbe\u5f0f\uff08\u53c8\u53eb\u505a\uff1aMustache\uff09\u7684\u8bed\u6cd5\u4e3a <code>{{ }}<\/code>\uff0cvue \u5728\u89e3\u6790\u6a21\u677f\u671f\u95f4\uff0c\u4f1a\u628a <code>{{ }}<\/code> \u6240\u5728\u7684\u4f4d\u7f6e\uff0c\u66ff\u6362\u4e3a\u5bf9\u5e94\u7684\u6570\u636e\u503c\uff0c\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;h1&gt;\u5927\u5bb6\u597d\uff0c\u6211\u662f\uff1a{{ name }}&lt;\/h1&gt;<\/code><\/pre>\n<p>vue \u4f1a\u628a <code>name<\/code> \u7684\u503c\uff0c\u66ff\u6362\u5230 <code>{{ name }}<\/code> \u6240\u5728\u7684\u4f4d\u7f6e\u3002<\/p>\n<blockquote>\n<p>\u6ce8\u610f\uff1a\u63d2\u503c\u8868\u8fbe\u5f0f {{ }} \u662f\u552f\u4e00\u4e00\u4e2a\u4e0d\u4ee5 v- \u524d\u7f00\u5f00\u5934\u7684\u6307\u4ee4\u3002<\/p>\n<\/blockquote>\n<h4>2. v-text<\/h4>\n<p><code>v-text<\/code> \u6307\u4ee4\u7528\u6765<strong>\u586b\u5145<\/strong> HTML \u5143\u7d20\u7684\u5185\u5bb9\uff0c\u5982\u679c HTML \u5143\u7d20\u5185\u90e8\u6709\u5176\u5b83\u5185\u5bb9\u5b58\u5728\uff0c\u5219\u4f1a\u88ab<strong>\u8986\u76d6<\/strong>\u6389\u3002\u8bed\u6cd5\u683c\u5f0f\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;h3 v-text=&quot;msg&quot;&gt;\u662f\u5144\u5f1f\u5c31\u6765&lt;\/h3&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      msg: &#039;\u780d\u6211\u5427&#039;\n    }\n  }\n})<\/code><\/pre>\n<blockquote>\n<p>\u6ce8\u610f\uff1a\u7531\u4e8e v-text \u6307\u4ee4\u5b58\u5728\u8986\u76d6\u5df2\u6709\u5185\u5bb9\u7684\u95ee\u9898\uff0c\u6240\u4ee5\u5728\u5b9e\u9645\u5f00\u53d1\u4e2d\u5b83\u5f88\u5c11\u88ab\u7528\u5230\u3002\u6700\u5e38\u7528\u7684\u8fd8\u662f {{ }} \u63d2\u503c\u8868\u8fbe\u5f0f\uff0c\u56e0\u4e3a\u5b83\u53ea\u662f\u5360\u4f4d\u7b26\uff0c\u4e0d\u4f1a\u8986\u76d6\u5df2\u6709\u5185\u5bb9\u3002<\/p>\n<\/blockquote>\n<h4>3. v-html<\/h4>\n<p><code>v-html<\/code> \u6307\u4ee4\u7528\u6765\u6e32\u67d3<strong>\u5e26\u6709 HTML \u6807\u8bb0\u7684\u6587\u672c\u5185\u5bb9<\/strong>\uff0c\u5b83\u53ef\u4ee5\u628a HTML \u6807\u8bb0\u89e3\u6790\u4e3a<strong>\u771f\u6b63\u7684 HTML \u5143\u7d20<\/strong>\uff0c\u5e76\u63d2\u5165\u5230\u6a21\u677f\u4e2d\u6e32\u67d3\u3002<\/p>\n<p>\u800c\u63d2\u503c\u8868\u8fbe\u5f0f\u548c v-text \u6307\u4ee4\u53ea\u4f1a\u628a HTML \u6807\u8bb0\u6e32\u67d3\u4e3a\u7eaf\u6587\u672c\uff0c\u800c\u4e0d\u662f HTML\u3002<\/p>\n<p>v-html \u7684\u8bed\u6cd5\u683c\u5f0f\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div v-html=&quot;rawHtml&quot;&gt;&lt;\/div&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      rawHtml: &#039;&lt;span style=&quot;color: red;&quot;&gt;\u5c11\u5e74\u5f3a\u5219\u56fd\u5f3a&lt;\/span&gt;&#039;\n    }\n  }\n})<\/code><\/pre>\n<h3>3.2 \u5c5e\u6027\u7ed1\u5b9a\u6307\u4ee4<\/h3>\n<h4>1. v-bind<\/h4>\n<p><code>v-bind<\/code> \u6307\u4ee4\u7528\u6765\u4e3a\u5143\u7d20\u7684<strong>\u5c5e\u6027<\/strong>\u7ed1\u5b9a<strong>\u52a8\u6001\u7684\u5c5e\u6027\u503c<\/strong>\u3002\u6307\u4ee4\u8bed\u6cd5\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div v-bind:title=&quot;titleMsg&quot;&gt;xxx&lt;\/div&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      titleMsg: &#039;\u54c7\u54c8\u54c8&#039;\n    }\n  }\n})<\/code><\/pre>\n<p>\u53c8\u4f8b\u5982\uff0c\u4e3a\u56fe\u7247\u7684 src \u5c5e\u6027\u52a8\u6001\u7ed1\u5b9a\u5c5e\u6027\u7684\u503c\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;img v-bind:src=&quot;url&quot; \/&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      url: &#039;https:\/\/img.yzcdn.cn\/vant\/cat.jpeg&#039;\n    }\n  }\n})<\/code><\/pre>\n<h4>2. v-bind \u7684\u7b80\u5199<\/h4>\n<p>\u5728\u5b9e\u9645\u5f00\u53d1\u4e2d\uff0c<code>v-bind<\/code> \u6307\u4ee4\u7684\u4f7f\u7528\u9891\u7387\u975e\u5e38\u9ad8\uff0c\u4e3a\u4e86\u7b80\u5316\u5b83\u7684\u5199\u6cd5\uff0cvue \u89c4\u5b9a <code>v-bind<\/code> \u6307\u4ee4\u53ef\u4ee5\u7b80\u5199\u4e3a\u82f1\u6587\u7684 <code>:<\/code> \u4e14\u4e8c\u8005\u662f\u5b8c\u5168\u7b49\u4ef7\u7684\u3002\u5982\u4e0a\u9762\u7684\u4f8b\u5b50\u53ef\u4ee5\u4f7f\u7528 <code>:<\/code> \u7b80\u5199\u4e3a\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div :title=&quot;titleMsg&quot;&gt;xxx&lt;\/div&gt;\n&lt;img :src=&quot;url&quot; \/&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      titleMsg: &#039;\u54c7\u54c8\u54c8&#039;,\n      url: &#039;https:\/\/img.yzcdn.cn\/vant\/cat.jpeg&#039;\n    }\n  }\n})<\/code><\/pre>\n<blockquote>\n<p>\u6ce8\u610f\uff1a\u4eca\u540e\u5728 vue \u9879\u76ee\u5f00\u53d1\u4e2d\uff0c\u53ea\u8981\u770b\u5230\u67d0\u4e2a\u5c5e\u6027\u524d\u9762\u51fa\u73b0\u4e86\u82f1\u6587\u7684 : \u90a3\u4e48\uff0c\u4e00\u5b9a\u662f\u4e3a\u8fd9\u4e2a\u5c5e\u6027\u7ed1\u5b9a\u4e86\u52a8\u6001\u7684\u503c\u3002<\/p>\n<\/blockquote>\n<h4>3. \u7ed1\u5b9a\u5e03\u5c14\u503c<\/h4>\n<p>\u5728 vue \u4e2d\uff0c\u67d0\u4e9b\u5c5e\u6027\u7684\u53d6\u503c\u53ef\u4ee5\u662f\u5e03\u5c14\u503c true \u6216 false\uff0c\u8868\u793a\u5f53\u524d\u7684\u5c5e\u6027\u662f\u5426\u5e94\u8be5<strong>\u5e94\u7528\u4e8e\u5f53\u524d\u7684\u5143\u7d20<\/strong>\u3002\u4f8b\u5982 <code>disabled<\/code> \u5c5e\u6027\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;!-- \u7981\u7528\u6309\u94aeA --&gt;\n&lt;button :disabled=&quot;true&quot;&gt;\u6309\u94aeA&lt;\/button&gt;\n\n&lt;!-- \u4e0d\u7981\u7528\u6309\u94aeB --&gt;\n&lt;button :disabled=&quot;false&quot;&gt;\u6309\u94aeB&lt;\/button&gt;<\/code><\/pre>\n<p>\u4e0e\u4e4b\u7c7b\u4f3c\u7684\uff0c\u8fd8\u6709 radio \u548c checkbox \u7684 <code>checked<\/code> \u5c5e\u6027\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;!-- \u9ed8\u8ba4\u9009\u4e2d\u201c\u7537\u201d --&gt;\n&lt;input type=&quot;radio&quot; name=&quot;gender&quot; :checked=&quot;true&quot;&gt;\u7537\n&lt;input type=&quot;radio&quot; name=&quot;gender&quot;&gt;\u5973\n\n&lt;!-- \u9ed8\u8ba4\u9009\u4e2d\u201c\u8db3\u7403\u201d\u548c\u201c\u4e52\u4e53\u7403\u201d --&gt;\n&lt;input type=&quot;checkbox&quot; name=&quot;hobby&quot;&gt;\u7bee\u7403\n&lt;input type=&quot;checkbox&quot; name=&quot;hobby&quot; :checked=&quot;true&quot;&gt;\u8db3\u7403\n&lt;input type=&quot;checkbox&quot; name=&quot;hobby&quot; :checked=&quot;true&quot;&gt;\u4e52\u4e53\u7403<\/code><\/pre>\n<p>\u53e6\u5916\uff0c\u8868\u5355\u5143\u7d20 <code>select<\/code> \u4e0b\u7684 <code>option<\/code> \u9009\u9879\u7684 <code>selected<\/code> \u5c5e\u6027\uff0c\u4e5f\u53ef\u4ee5\u7ed1\u5b9a\u5e03\u5c14\u503c\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;select&gt;\n  &lt;option value=&quot;\u5317\u4eac&quot;&gt;\u5317\u4eac&lt;\/option&gt;\n  &lt;option value=&quot;\u4e0a\u6d77&quot; :selected=&quot;true&quot;&gt;\u4e0a\u6d77&lt;\/option&gt;\n  &lt;option value=&quot;\u5e7f\u5dde&quot;&gt;\u5e7f\u5dde&lt;\/option&gt;\n&lt;\/select&gt;<\/code><\/pre>\n<h4>4. \u52a8\u6001\u7ed1\u5b9a\u591a\u4e2a\u503c<\/h4>\n<p>\u5982\u679c\u8981\u4e3a\u67d0\u4e2a\u5143\u7d20<strong>\u540c\u65f6\u7ed1\u5b9a\u591a\u4e2a<\/strong>\u52a8\u6001\u7684\u5c5e\u6027\u503c\uff0c\u53ef\u4ee5\u628a\u591a\u4e2a\u52a8\u6001\u5c5e\u6027\u5c01\u88c5\u4e3a\u4e00\u4e2a JavaScript \u5bf9\u8c61\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      \/\/ propObj \u5bf9\u8c61\u4e2d\u5c01\u88c5\u4e86\u4e00\u7cfb\u5217\u5c5e\u6027\u7684\u952e\u503c\u5bf9\n      attrsObj: {\n        id: &#039;box&#039;,\n        class: &#039;container&#039;,\n        title: &#039;\u5e03\u5c40\u5bb9\u5668&#039;\n      }\n    }\n  }\n})<\/code><\/pre>\n<p>\u901a\u8fc7<strong>\u4e0d\u5e26\u53c2\u6570\u7684<\/strong> <code>v-bind<\/code> \u6307\u4ee4\uff0c\u5373\u53ef\u65b9\u4fbf\u7684\u628a attrsObj \u5bf9\u8c61\u4e2d\u5c01\u88c5\u7684\u5c5e\u6027\uff0c\u4e00\u6b21\u6027\u7ed1\u5b9a\u5230\u5bf9\u5e94\u7684\u5143\u7d20\u4e0a\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div v-bind=&quot;attrsObj&quot;&gt;\u9876\u90e8 header \u533a\u57df&lt;\/div&gt;<\/code><\/pre>\n<blockquote>\n<p>\u6ce8\u610f\uff1a\u4e0d\u5e26\u53c2\u6570\u7684 v-bind \u6307\u4ee4\uff0c\u6307\u7684\u662f\u7701\u7565\u4e86 <code>:\u5c5e\u6027\u540d<\/code> \u7684\u7528\u6cd5\u3002<\/p>\n<\/blockquote>\n<h4>5. \u62d3\u5c55\uff1a\u4f7f\u7528 JavaScript \u8868\u8fbe\u5f0f<\/h4>\n<ol>\n<li>\n<p>\u5728 vue \u7684\u6570\u636e\u7ed1\u5b9a\u4e2d\uff0c\u9664\u4e86\u652f\u6301\u7b80\u5355\u7684<strong>\u5c5e\u6027\u540d\u7ed1\u5b9a<\/strong>\u4e4b\u5916\uff0c\u8fd8\u652f\u6301<strong>\u5b8c\u6574\u7684 JavaScript \u8868\u8fbe\u5f0f\u7ed1\u5b9a<\/strong>\u3002<\/p>\n<\/li>\n<li>\n<p>\u4f8b\u5982\uff0c\u4ee5\u4e0b\u8fd9\u4e9b\u90fd\u5c5e\u4e8e\u7b80\u5355\u7684\u5c5e\u6027\u540d\u7ed1\u5b9a\uff0c\u5b83\u4eec\u662f\u76f4\u63a5\u628a data \u4e2d\u6570\u636e\u9879\u7684\u540d\u5b57\uff0c\u7ed1\u5b9a\u5230\u4e86\u6a21\u677f\u4e2d\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div&gt;\u6211\u662f\uff1a{{ name }}&lt;\/div&gt;\n\n&lt;div v-text=&quot;msg&quot;&gt;&lt;\/div&gt;\n\n&lt;img :src=&quot;url&quot; \/&gt;<\/code><\/pre>\n<\/li>\n<li>\n<p>\u9664\u6b64\u4e4b\u5916\uff0c\u8fd8\u652f\u6301\u8868\u8fbe\u5f0f\u7684\u7ed1\u5b9a\uff0c\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;!-- \u51fd\u6570\u7684\u8c03\u7528 &amp; \u6570\u5b66\u8fd0\u7b97 --&gt;\n&lt;div&gt;\u6211\u662f\uff1a{{ name.toUpperCase() }}\uff0c\u6211\u4eca\u5e74{{ age + 1 }}\u5c81\u4e86\u3002&lt;\/div&gt;\n\n&lt;!-- \u51fd\u6570\u7684\u8c03\u7528 --&gt;\n&lt;div v-text=&quot;msg.split(&#039;&#039;).reverse().join(&#039;&#039;)&quot;&gt;&lt;\/div&gt;\n\n&lt;!-- \u5b57\u7b26\u4e32\u7684\u62fc\u63a5 --&gt;\n&lt;img :src=&quot;&#039;https:\/\/img.yzcdn.cn\/vant\/&#039; + url&quot; \/&gt;\n\n&lt;!-- \u4e09\u5143\u8868\u8fbe\u5f0f --&gt;\n&lt;div&gt;{{ age &gt;= 18 ? &#039;\u62bd\u70df\u559d\u9152\u70eb\u5934&#039; : &#039;\u53ef\u4e50\u725b\u5976\u5a03\u54c8\u54c8&#039; }}&lt;\/div&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n data() {\n   return {\n     name: 'liulongbin',\n     age: 17,\n     msg: '\u51af\u7ecd\u5cf0',\n     url: 'cat.jpeg'\n   }\n }\n})<\/code><\/pre>\n<\/li>\n<\/ol>\n<h3>3.3 \u53cc\u5411\u7ed1\u5b9a\u6307\u4ee4<\/h3>\n<p><code>v-model<\/code> \u53cc\u5411\u7ed1\u5b9a\u6307\u4ee4\uff0c\u7b80\u5316\u4e86<strong>\u8868\u5355\u5143\u7d20<\/strong>\u7684<strong>\u8d4b\u503c\u548c\u53d6\u503c<\/strong>\u64cd\u4f5c\u3002<\/p>\n<p><code>v-model<\/code> \u7684\u4f5c\u7528\uff1a<\/p>\n<ol>\n<li>data \u6570\u636e\u6e90\u53d1\u751f\u53d8\u5316\uff0c\u81ea\u52a8\u91cd\u65b0\u6e32\u67d3\u9875\u9762<\/li>\n<li>\u8868\u5355\u6570\u636e\u53d1\u751f\u53d8\u5316\uff0c\u81ea\u52a8\u66f4\u65b0\u5230 data \u6570\u636e\u6e90\u4e2d<\/li>\n<\/ol>\n<h4>1. \u6587\u672c\u6846\u7684\u53cc\u5411\u7ed1\u5b9a<\/h4>\n<p>input \u5143\u7d20\u901a\u8fc7 v-model \u6307\u4ee4\uff0c\u53ef\u4ee5\u65b9\u4fbf\u5730\u8fdb\u884c\u8d4b\u503c\u548c\u53d6\u503c\uff0c\u793a\u4f8b\u4ee3\u7801\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;p&gt;Message \u7684\u503c\u662f\uff1a{{ message }}&lt;\/p&gt;\n&lt;input type=&quot;text&quot; v-model=&quot;message&quot;&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      message: &#039;hello&#039;\n    }\n  }\n})<\/code><\/pre>\n<h4>2. \u591a\u884c\u6587\u672c\u6846\u7684\u53cc\u5411\u7ed1\u5b9a<\/h4>\n<p>textarea \u5143\u7d20\u901a\u8fc7 v-model \u6307\u4ee4\uff0c\u53ef\u4ee5\u65b9\u4fbf\u5730\u8fdb\u884c\u8d4b\u503c\u548c\u53d6\u503c\uff0c\u793a\u4f8b\u4ee3\u7801\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;p&gt;Message \u7684\u503c\u662f\uff1a&lt;\/p&gt;\n&lt;pre&gt;{{ message }}&lt;\/pre&gt;\n&lt;textarea v-model=&quot;message&quot;&gt;&lt;\/textarea&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      \/\/ \u6ce8\u610f\uff1a\u8fd9\u91cc\u7684 \\n \u662f\u6362\u884c\u7b26\n      message: &#039;hello \\nworld.&#039;\n    }\n  }\n})<\/code><\/pre>\n<h4>3. \u590d\u9009\u6846\u7684\u53cc\u5411\u7ed1\u5b9a<\/h4>\n<ol>\n<li>\n<p><strong>\u5355\u4e00\u590d\u9009\u6846<\/strong>\u7684\u53cc\u5411\u7ed1\u5b9a\uff0c\u7ed1\u5b9a\u7684\u662f<strong>\u5e03\u5c14\u7c7b\u578b<\/strong>\u7684\u503c\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;p&gt;\u590d\u9009\u6846\u9009\u4e2d\u7684flag\u503c\u4e3a\uff1a{{flag}}&lt;\/p&gt;\n&lt;input type=&quot;checkbox&quot; v-model=&quot;flag&quot;&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n data() {\n   return {\n     \/\/ \u662f\u5426\u88ab\u9009\u4e2d\n     flag: false\n   }\n }\n})<\/code><\/pre>\n<\/li>\n<li>\n<p><strong>\u591a\u4e2a\u590d\u9009\u6846<\/strong>\u7684\u53cc\u5411\u7ed1\u5b9a\uff0c\u7ed1\u5b9a\u7684\u662f<strong>\u6570\u7ec4\u7c7b\u578b<\/strong>\u7684\u503c\uff0c\u800c\u4e14\u6bcf\u4e2a checkbox \u5fc5\u987b\u901a\u8fc7 <strong>value \u5c5e\u6027<\/strong>\u63d0\u4f9b<strong>\u9009\u4e2d\u9879\u7684\u503c<\/strong>\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;p&gt;\u591a\u4e2a\u590d\u9009\u6846\u9009\u4e2d\u7684 hobbies \u503c\u4e3a\uff1a{{ hobbies }}&lt;\/p&gt;\n&lt;label&gt;&lt;input type=&quot;checkbox&quot; v-model=&quot;hobbies&quot; value=&quot;\u7bee\u7403&quot;&gt;\u7bee\u7403&lt;\/label&gt;\n&lt;label&gt;&lt;input type=&quot;checkbox&quot; v-model=&quot;hobbies&quot; value=&quot;\u8db3\u7403&quot;&gt;\u8db3\u7403&lt;\/label&gt;\n&lt;label&gt;&lt;input type=&quot;checkbox&quot; v-model=&quot;hobbies&quot; value=&quot;\u51b0\u7403&quot;&gt;\u51b0\u7403&lt;\/label&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n data() {\n   return {\n     \/\/ \u9009\u4e2d\u7684\u503c\n     hobbies: []\n   }\n }\n})<\/code><\/pre>\n<\/li>\n<\/ol>\n<h4>4. \u5355\u9009\u6309\u94ae\u7684\u53cc\u5411\u7ed1\u5b9a<\/h4>\n<p>\u5355\u9009\u6309\u94ae\u7684\u7279\u70b9\u662f\u591a\u9009\u4e00\uff0c\u6240\u4ee5\u5bf9\u5355\u9009\u6309\u94ae\u8fdb\u884c\u53cc\u5411\u7ed1\u5b9a\u65f6\uff0c\u9700\u8981\u628a\u591a\u4e2a\u5355\u9009\u6309\u94ae\u901a\u8fc7 v-model \u6307\u4ee4\u7ed1\u5b9a\u5230\u540c\u4e00\u4e2a\u6570\u636e\u6e90\uff0c\u5e76\u901a\u8fc7 value \u5c5e\u6027\u6307\u5b9a\u9009\u4e2d\u540e\u7684\u503c\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;p&gt;\u5355\u9009\u6309\u94ae\u9009\u4e2d\u7684 gender \u503c\u4e3a\uff1a{{ gender }}&lt;\/p&gt;\n&lt;label&gt;&lt;input type=&quot;radio&quot; v-model=&quot;gender&quot; value=&quot;\u7537&quot;&gt;\u7537&lt;\/label&gt;\n&lt;label&gt;&lt;input type=&quot;radio&quot; v-model=&quot;gender&quot; value=&quot;\u5973&quot;&gt;\u5973&lt;\/label&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      \/\/ \u9009\u4e2d\u7684\u503c\n      gender: &#039;\u7537&#039;\n    }\n  }\n})<\/code><\/pre>\n<h4>5. \u9009\u62e9\u5668\u7684\u53cc\u5411\u7ed1\u5b9a<\/h4>\n<ol>\n<li>\n<p>\u5355\u9009<strong>\u9009\u62e9\u5668<\/strong>\u7684\u53cc\u5411\u7ed1\u5b9a\uff0c\u53ea\u5141\u8bb8\u9009\u4e2d\u4e00\u4e2a\u503c\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;p&gt;\u9009\u4e2d\u7684\u57ce\u5e02\u4e3a\uff1a{{ city }}&lt;\/p&gt;\n&lt;select v-model=&quot;city&quot;&gt;\n &lt;option value=&quot;&quot;&gt;\u8bf7\u9009\u62e9&lt;\/option&gt;\n &lt;option value=&quot;beijing&quot;&gt;\u5317\u4eac&lt;\/option&gt;\n &lt;option value=&quot;shanghai&quot;&gt;\u4e0a\u6d77&lt;\/option&gt;\n &lt;option value=&quot;nanjing&quot;&gt;\u5357\u4eac&lt;\/option&gt;\n&lt;\/select&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n data() {\n   return {\n     city: ''\n   }\n }\n})<\/code><\/pre>\n<\/li>\n<li>\n<p>\u591a\u9009<strong>\u9009\u62e9\u5668<\/strong>\u7684\u53cc\u5411\u7ed1\u5b9a\uff0c\u5141\u8bb8\u9009\u4e2d\u591a\u4e2a\u503c\uff0c\u6240\u4ee5\u9700\u8981\u7ed1\u5b9a<strong>\u6570\u7ec4\u683c\u5f0f<\/strong>\u7684\u6570\u636e\u6e90\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;p&gt;\u9009\u4e2d\u7684\u57ce\u5e02\u4e3a\uff1a{{ areas }}&lt;\/p&gt;\n&lt;select v-model=&quot;areas&quot; multiple&gt;\n &lt;option value=&quot;shunyi&quot;&gt;\u987a\u4e49\u533a&lt;\/option&gt;\n &lt;option value=&quot;haidian&quot;&gt;\u6d77\u6dc0\u533a&lt;\/option&gt;\n &lt;option value=&quot;daxing&quot;&gt;\u5927\u5174\u533a&lt;\/option&gt;\n&lt;\/select&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n data() {\n   return {\n     areas: []\n   }\n }\n})<\/code><\/pre>\n<\/li>\n<\/ol>\n<h4>6. v-model \u7684 .lazy \u4fee\u9970\u7b26<\/h4>\n<p>\u9ed8\u8ba4\u60c5\u51b5\u4e0b\uff0c<code>v-model<\/code> \u4f1a\u5728\u6bcf\u6b21 <code>input<\/code> \u4e8b\u4ef6\u540e\u66f4\u65b0\u6570\u636e\u3002\u53ef\u4ee5\u6dfb\u52a0 <code>.lazy<\/code> \u4fee\u9970\u7b26\u6765\u6539\u4e3a\u5728\u6bcf\u6b21 <code>change<\/code> \u4e8b\u4ef6\u540e\u66f4\u65b0\u6570\u636e\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;input v-model.lazy=&quot;msg&quot; \/&gt;<\/code><\/pre>\n<h4>7. v-model \u7684 .number \u4fee\u9970\u7b26<\/h4>\n<p>\u5982\u679c\u4f60\u60f3\u8ba9\u7528\u6237\u8f93\u5165\u81ea\u52a8\u8f6c\u6362\u4e3a\u6570\u5b57\uff0c\u4f60\u53ef\u4ee5\u5728 <code>v-model<\/code> \u540e\u6dfb\u52a0 <code>.number<\/code> \u4fee\u9970\u7b26\u6765\u7ba1\u7406\u8f93\u5165\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;input v-model.number=&quot;age&quot; \/&gt;<\/code><\/pre>\n<p>\u6ce8\u610f\uff1a<\/p>\n<ol>\n<li>\u5982\u679c\u8be5\u503c\u65e0\u6cd5\u88ab <code>parseFloat()<\/code> \u5904\u7406\uff0c\u90a3\u4e48\u5c06\u8fd4\u56de\u539f\u59cb\u503c\u3002<\/li>\n<li><code>number<\/code> \u4fee\u9970\u7b26\u4f1a\u5728\u8f93\u5165\u6846\u6709 <code>type=&quot;number&quot;<\/code> \u65f6\u81ea\u52a8\u542f\u7528\u3002<\/li>\n<\/ol>\n<h4>8. v-model \u7684 .trim \u4fee\u9970\u7b26<\/h4>\n<p>\u5982\u679c\u4f60\u60f3\u8981\u9ed8\u8ba4\u81ea\u52a8\u53bb\u9664\u7528\u6237\u8f93\u5165\u5185\u5bb9\u4e2d\u4e24\u7aef\u7684\u7a7a\u683c\uff0c\u4f60\u53ef\u4ee5\u5728 <code>v-model<\/code> \u540e\u6dfb\u52a0 <code>.trim<\/code> \u4fee\u9970\u7b26\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;input v-model.trim=&quot;msg&quot; \/&gt;<\/code><\/pre>\n<h3>3.4 \u6761\u4ef6\u6e32\u67d3\u6307\u4ee4<\/h3>\n<p>\u6761\u4ef6\u6e32\u67d3\u6307\u4ee4\u7528\u6765\u6761\u4ef6\u6027\u5730\u6e32\u67d3\u9875\u9762\u4e0a\u7684\u67d0\u4e00\u90e8\u5206\u5185\u5bb9\u3002\u53ea\u6709\u8868\u8fbe\u5f0f\u7684\u6761\u4ef6\u6210\u7acb\uff0c\u624d\u4f1a\u771f\u6b63\u6e32\u67d3\u8fd9\u4e00\u90e8\u5206\u7684\u5185\u5bb9\u3002<\/p>\n<p>\u5e38\u7528\u7684\u6761\u4ef6\u6e32\u67d3\u6307\u4ee4\u662f <code>v-if<\/code>\u3001<code>v-else<\/code> \u548c <code>v-else-if<\/code>\u3002\u5176\u4e2d\uff0c<code>v-if<\/code> \u6307\u4ee4\u53ef\u4ee5\u5355\u72ec\u4f7f\u7528\uff0c\u4e5f\u53ef\u4ee5\u7ed3\u5408 <code>v-else<\/code> \u548c <code>v-else-if<\/code> \u6307\u4ee4\u5b9e\u73b0<strong>\u4e24\u4e2a<\/strong>\u6216<strong>\u591a\u4e2a<\/strong>\u6761\u4ef6\u7684\u6309\u9700\u6e32\u67d3\u3002<\/p>\n<h4>1. v-if \u7684\u4f7f\u7528<\/h4>\n<p>v-if \u7684\u8bed\u6cd5\u683c\u5f0f\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div v-if=&quot;\u8868\u8fbe\u5f0f&quot;&gt;&lt;\/div&gt;<\/code><\/pre>\n<p>\u5176\u4e2d\uff0c\u53ea\u6709\u8868\u8fbe\u5f0f\u7684\u8fd4\u56de\u503c\u4e3a true \u65f6\uff0c\u624d\u4f1a\u771f\u6b63\u6e32\u67d3\u88ab v-if \u6307\u4ee4\u63a7\u5236\u7684 div \u5143\u7d20\u3002<\/p>\n<p>\u5982\u679c v-if \u7684\u8868\u8fbe\u5f0f\u8fd4\u56de\u503c\u4e3a false\uff0c\u5219\u88ab v-if \u6307\u4ee4\u63a7\u5236\u7684 div \u4e0d\u4f1a\u88ab\u6e32\u67d3\u5230\u6d4f\u89c8\u5668\u4e2d\u3002<\/p>\n<p>\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div v-if=&quot;flag&quot;&gt;\u65e0\u654c\u662f\u591a\u4e48\u7684\u5bc2\u5bde&lt;\/div&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      flag: true\n    }\n  }\n})<\/code><\/pre>\n<h4>2. v-if \u7ed3\u5408 v-else \u7684\u4f7f\u7528<\/h4>\n<p><code>v-if<\/code> \u6307\u4ee4\u53ef\u4ee5\u7ed3\u5408 <code>v-else<\/code> \u6307\u4ee4\u4e00\u8d77\u4f7f\u7528\u3002<\/p>\n<p>\u5f53<strong>\u6761\u4ef6\u4e3a\u771f<\/strong>\u65f6\u6e32\u67d3\u88ab <code>v-if<\/code> \u6307\u4ee4\u63a7\u5236\u7684\u5143\u7d20\uff0c\u5f53<strong>\u6761\u4ef6\u4e3a\u5047<\/strong>\u65f6\u6e32\u67d3\u88ab <code>v-else<\/code> \u6307\u4ee4\u63a7\u5236\u7684\u5143\u7d20\u3002\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div v-if=&quot;age &gt;= 18&quot;&gt;\u62bd\u70df\u559d\u9152\u70eb\u5934&lt;\/div&gt;\n&lt;div v-else&gt;\u725b\u5976\u53ef\u4e50\u5a03\u54c8\u54c8&lt;\/div&gt;<\/code><\/pre>\n<blockquote>\n<p>\u6ce8\u610f\uff1av-else \u6307\u4ee4\u4e0d\u9700\u8981\u901a\u8fc7 = \u6307\u5b9a\u76f8\u5e94\u7684\u8868\u8fbe\u5f0f\uff0c\u56e0\u4e3a <strong>v-else \u662f\u515c\u5e95\u7684\u6761\u4ef6<\/strong>\uff0c\u53ea\u8981\u524d\u9762\u7684\u6240\u6709\u6761\u4ef6\u90fd\u4e0d\u6ee1\u8db3\uff0c\u90a3\u4e48\u5fc5\u7136\u4f1a\u89e6\u53d1 v-else \u7684\u6267\u884c\u3002<\/p>\n<\/blockquote>\n<h4>3. v-if \u7ed3\u5408 v-else-if \u548c v-else \u7684\u4f7f\u7528<\/h4>\n<p><code>v-if<\/code> \u6307\u4ee4\u53ef\u4ee5\u7ed3\u5408 <code>v-else-if<\/code> \u548c <code>v-else<\/code> \u6307\u4ee4\u4e00\u8d77\u4f7f\u7528\uff0c\u4ece\u800c\u7ec4\u6210\u590d\u6742\u7684\u6761\u4ef6\u6e32\u67d3\u903b\u8f91\u3002<\/p>\n<p>\u5f53 <code>v-if<\/code> \u6216\u67d0\u4e2a <code>v-else-if<\/code> \u76f8\u5e94\u7684\u6761\u4ef6\u4e3a\u771f\u65f6\uff0c\u88ab\u63a7\u5236\u7684\u5143\u7d20\u624d\u4f1a\u88ab\u6e32\u67d3\u3002<\/p>\n<p>\u6700\u540e\u7684 <code>v-else<\/code> \u4f9d\u7136\u662f\u515c\u5e95\u7684\u6761\u4ef6\uff0c\u5f53\u6240\u6709\u7684 <code>v-if<\/code> \u548c <code>v-else-if<\/code> \u6761\u4ef6\u90fd\u4e0d\u6210\u7acb\u65f6\uff0c\u624d\u4f1a\u89e6\u53d1 v-else \u7684\u6267\u884c\u3002\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div v-if=&quot;score === &#039;A&#039;&quot;&gt;\u4f18\u79c0&lt;\/div&gt;\n&lt;div v-else-if=&quot;score === &#039;B&#039;&quot;&gt;\u826f\u597d&lt;\/div&gt;\n&lt;div v-else-if=&quot;score === &#039;C&#039;&quot;&gt;\u4e00\u822c&lt;\/div&gt;\n&lt;div v-else&gt;\u5dee&lt;\/div&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      score: &#039;A&#039;\n    }\n  }\n})<\/code><\/pre>\n<h4>4. &lt;template&gt; \u4e0a\u7684 v-if<\/h4>\n<p>\u6b63\u5e38\u60c5\u51b5\u4e0b <code>v-if<\/code> \u6307\u4ee4\u53ea\u80fd\u63a7\u5236<strong>\u5355\u4e2a\u5143\u7d20<\/strong>\u7684\u663e\u793a\u548c\u9690\u85cf\u3002\u5982\u679c\u9700\u8981\u4f7f\u7528 <code>v-if<\/code> \u63a7\u5236<strong>\u4e00\u7ec4\u5143\u7d20<\/strong>\u7684\u663e\u793a\u548c\u9690\u85cf\uff0c\u5c31\u9700\u8981\u5728\u8fd9\u4e00\u7ec4\u5143\u7d20\u4e4b\u5916<strong>\u5305\u88f9\u4e00\u4e2a div \u4f5c\u4e3a\u5bb9\u5668<\/strong>\uff0c\u5e76\u5c06 <code>v-if<\/code> \u6307\u4ee4<strong>\u5e94\u7528\u4e8e div \u5bb9\u5668\u4e4b\u4e0a<\/strong>\uff0c\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div v-if=&quot;true&quot;&gt;\n  &lt;h1&gt;\u548f\u9e45&lt;\/h1&gt;\n  &lt;p&gt;\u9e45\u9e45\u9e45\uff0c\u66f2\u9879\u5411\u5929\u6b4c\u3002&lt;\/p&gt;\n  &lt;p&gt;\u767d\u6bdb\u6d6e\u7eff\u6c34\uff0c\u7ea2\u638c\u62e8\u6e05\u6ce2\u3002&lt;\/p&gt;\n&lt;\/div&gt;<\/code><\/pre>\n<p>\u8fd9\u4e48\u505a\u867d\u7136\u80fd\u5b9e\u73b0\u9700\u6c42\uff0c\u4f46\u4f1a\u5728\u9875\u9762\u4e0a\u6e32\u67d3\u51fa\u4e00\u4e2a\u591a\u4f59\u7684 div \u5bb9\u5668\u3002<\/p>\n<p>\u66f4\u597d\u7684\u65b9\u6848\u662f\u4f7f\u7528 vue \u5185\u7f6e\u7684 <code>&lt;template&gt;<\/code> \u5143\u7d20\u4f5c\u4e3a\u5916\u5c42\u5305\u88f9\u6027\u8d28\u7684\u5bb9\u5668\uff0c\u56e0\u4e3a<strong>\u5b83\u4e0d\u4f1a\u88ab\u6e32\u67d3\u4e3a\u5b9e\u9645\u7684\u5143\u7d20\uff0c\u53ea\u8d77\u5230\u5305\u88f9\u6027\u8d28\u7684\u4f5c\u7528<\/strong>\u3002\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;template v-if=&quot;true&quot;&gt;\n  &lt;h1&gt;\u548f\u9e45&lt;\/h1&gt;\n  &lt;p&gt;\u9e45\u9e45\u9e45\uff0c\u66f2\u9879\u5411\u5929\u6b4c\u3002&lt;\/p&gt;\n  &lt;p&gt;\u767d\u6bdb\u6d6e\u7eff\u6c34\uff0c\u7ea2\u638c\u62e8\u6e05\u6ce2\u3002&lt;\/p&gt;\n&lt;\/template&gt;<\/code><\/pre>\n<h4>5. v-show \u6307\u4ee4\u7684\u4f7f\u7528<\/h4>\n<p>\u53e6\u4e00\u4e2a\u53ef\u4ee5\u7528\u6765\u5b9e\u73b0\u6761\u4ef6\u6e32\u67d3\u7684\u6307\u4ee4\u662f <code>v-show<\/code>\u3002\u5b83\u7684\u8bed\u6cd5\u683c\u5f0f\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;h1 v-show=&quot;flag&quot;&gt;Hello!&lt;\/h1&gt;<\/code><\/pre>\n<p>\u5982\u679c\u8868\u8fbe\u5f0f\u7684\u503c\u4e3a <strong>true<\/strong>\uff0c\u5219\u88ab\u63a7\u5236\u7684\u5143\u7d20\u4f1a\u88ab<strong>\u663e\u793a<\/strong>\uff1b<\/p>\n<p>\u5982\u679c\u8868\u8fbe\u5f0f\u7684\u503c\u4e3a <strong>false<\/strong>\uff0c\u5219\u88ab\u63a7\u5236\u7684\u5143\u7d20\u4f1a\u88ab<strong>\u9690\u85cf<\/strong>\u3002<\/p>\n<blockquote>\n<p>\u6ce8\u610f\uff1av-show \u6307\u4ee4\u4e0d\u652f\u6301\u5728 &lt;template&gt;\u00a0\u5143\u7d20\u4e0a\u4f7f\u7528\uff0c\u4e5f\u4e0d\u80fd\u548c v-else \u642d\u914d\u4f7f\u7528\u3002<\/p>\n<\/blockquote>\n<h4>6. v-if \u548c v-show \u7684\u5bf9\u6bd4<\/h4>\n<p><strong>\u76f8\u540c\u70b9\uff1a<\/strong><\/p>\n<p><code>v-if<\/code> \u548c <code>v-show<\/code> \u6307\u4ee4\u90fd\u80fd\u63a7\u5236\u5143\u7d20\u7684\u6761\u4ef6\u6e32\u67d3\u3002<\/p>\n<ol>\n<li>\u5982\u679c\u8868\u8fbe\u5f0f\u7684\u503c\u4e3a <strong>true<\/strong>\uff0c\u5219\u88ab\u63a7\u5236\u7684\u5143\u7d20\u4f1a\u88ab<strong>\u663e\u793a<\/strong>\uff1b<\/li>\n<li>\u5982\u679c\u8868\u8fbe\u5f0f\u7684\u503c\u4e3a <strong>false<\/strong>\uff0c\u5219\u88ab\u63a7\u5236\u7684\u5143\u7d20\u4f1a\u88ab<strong>\u9690\u85cf<\/strong>\u3002<\/li>\n<\/ol>\n<p><strong>\u4e0d\u540c\u70b9\uff1a<\/strong><\/p>\n<ol>\n<li>\u63a7\u5236\u5143\u7d20\u663e\u793a\u548c\u9690\u85cf\u7684<strong>\u624b\u6bb5\u4e0d\u540c<\/strong>\uff1a\n<ul>\n<li><code>v-if<\/code> \u6307\u4ee4\u4f1a\u52a8\u6001<strong>\u521b\u5efa<\/strong>\u548c<strong>\u5220\u9664<\/strong>\u88ab\u63a7\u5236\u7684\u5143\u7d20\uff0c\u4ece\u800c\u8fbe\u5230\u5207\u6362\u5143\u7d20\u663e\u793a\u548c\u9690\u85cf\u7684\u76ee\u7684\uff1b<\/li>\n<li><code>v-show<\/code> \u6307\u4ee4\u4ec5<strong>\u5207\u6362<\/strong>\u4e86\u88ab\u63a7\u5236\u5143\u7d20\u4e0a\u540d\u4e3a <code>display<\/code> \u7684 CSS \u5c5e\u6027\uff0c\u4ece\u800c\u8fbe\u5230\u5207\u6362\u5143\u7d20\u663e\u793a\u548c\u9690\u85cf\u7684\u76ee\u7684\uff1b<\/li>\n<\/ul>\n<\/li>\n<li><strong>\u521d\u59cb\u6e32\u67d3<\/strong>\u7684<strong>\u6027\u80fd<\/strong>\u4e0d\u540c\uff1a\n<ul>\n<li>\u5982\u679c\u521d\u59cb\u6e32\u67d3\u65f6\uff0c\u8868\u8fbe\u5f0f\u7684\u503c\u4e3a false\uff0c\u5219 v-if \u7684\u6027\u80fd\u66f4\u597d\u3002<\/li>\n<li>\u5982\u679c\u521d\u59cb\u6e32\u67d3\u65f6\uff0c\u8868\u8fbe\u5f0f\u7684\u503c\u4e3a true\uff0c\u5219\u4e8c\u8005\u6027\u80fd\u76f8\u8fd1\u3002<\/li>\n<\/ul>\n<\/li>\n<li><strong>\u9891\u7e41\u5207\u6362<\/strong>\u65f6\u7684<strong>\u6027\u80fd<\/strong>\u4e0d\u540c\uff1a\n<ul>\n<li>\u5982\u679c\u9700\u8981\u9891\u7e41\u5207\u6362\u5143\u7d20\u7684\u663e\u793a\u548c\u9690\u85cf\uff0c\u5219 v-show \u7684\u6027\u80fd\u66f4\u597d\u3002<\/li>\n<li>\u5982\u679c\u4e0d\u9700\u8981\u9891\u7e41\u5207\u6362\u5143\u7d20\u7684\u663e\u793a\u548c\u9690\u85cf\uff0c\u5219\u53ef\u4ee5\u5ffd\u7565\u4e8c\u8005\u7684\u6027\u80fd\u5dee\u522b\u3002<\/li>\n<\/ul>\n<\/li>\n<li>\u603b\u7ed3\uff1a\n<ul>\n<li><code>v-if<\/code> \u6709\u66f4\u9ad8\u7684<strong>\u5207\u6362\u5f00\u9500<\/strong><\/li>\n<li><code>v-show<\/code> \u6709\u66f4\u9ad8\u7684<strong>\u521d\u59cb\u6e32\u67d3\u5f00\u9500<\/strong><\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<h3>3.5 \u4e8b\u4ef6\u7ed1\u5b9a\u6307\u4ee4<\/h3>\n<h4>1. \u4e8b\u4ef6\u7ed1\u5b9a\u7684\u57fa\u672c\u8bed\u6cd5<\/h4>\n<p>\u4e3a\u4e86\u54cd\u5e94\u7528\u6237\u5bf9 DOM \u5143\u7d20\u7684\u64cd\u4f5c\uff0cvue \u63d0\u4f9b\u4e86\u4e8b\u4ef6\u7ed1\u5b9a\u6307\u4ee4 <code>v-on<\/code>\uff08\u7b80\u5199\u4e3a <code>@<\/code>\uff09\u3002<\/p>\n<p>\u5f53\u76d1\u542c\u5230 DOM \u4e8b\u4ef6\u7684\u89e6\u53d1\u65f6\uff0c\u4f1a\u6267\u884c\u5bf9\u5e94\u7684 JavaScript \u903b\u8f91\u3002\u5b83\u7684\u8bed\u6cd5\u683c\u5f0f\u4e3a <code>v-on:\u4e8b\u4ef6\u540d=&quot;handler&quot;<\/code> \u6216 <code>@\u4e8b\u4ef6\u540d=&quot;handler&quot;<\/code>\u3002\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;!-- v-on \u662f\u4e8b\u4ef6\u7ed1\u5b9a\u6307\u4ee4 --&gt;\n&lt;button v-on:click=&quot;show&quot;&gt;\u6309\u94ae&lt;\/button&gt;\n\n&lt;!-- @ \u662f v-on \u6307\u4ee4\u7684\u7b80\u5199\u5f62\u5f0f --&gt;\n&lt;button @click=&quot;show&quot;&gt;\u6309\u94ae&lt;\/button&gt;<\/code><\/pre>\n<p>\u4e0a\u8ff0\u4ee3\u7801\u6f14\u793a\u4e86\u5982\u4f55\u4e3a button \u6309\u94ae\u7ed1\u5b9a <code>click<\/code> \u70b9\u51fb\u4e8b\u4ef6\u3002<\/p>\n<p>\u9664\u6b64\u4e4b\u5916\uff0cvue \u8fd8\u652f\u6301\u7ed1\u5b9a\u5176\u5b83\u7c7b\u578b\u7684\u4e8b\u4ef6\uff0c\u8fd9\u91cc\u5c31\u4e0d\u518d\u4e00\u4e00\u4f8b\u4e3e\u4e86\u3002\u56e0\u4e3a\u628a DOM \u539f\u751f\u4e8b\u4ef6\u524d\u9762\u7684 <code>on<\/code> \u66ff\u6362\u6210 <code>v-on:<\/code> \u6216 <code>@<\/code> \u5c31\u53d8\u6210\u4e86 vue \u7684\u4e8b\u4ef6\u7ed1\u5b9a\u5f62\u5f0f\uff0c\u4f8b\u5982\uff1a<\/p>\n<ol>\n<li>onclick  &#8211;&gt;  <strong>@click<\/strong><\/li>\n<li>oninput  &#8211;&gt;  <strong>@input<\/strong><\/li>\n<li>onchange  &#8211;&gt;  <strong>@change<\/strong><\/li>\n<\/ol>\n<h4>2. \u65b9\u6cd5\u4e8b\u4ef6\u5904\u7406\u5668<\/h4>\n<p>\u65b9\u6cd5\u4e8b\u4ef6\u5904\u7406\u5668\u6307\u7684\u662f\uff1a<strong>\u6307\u5b9a\u4e00\u4e2a\u65b9\u6cd5\u4f5c\u4e3a\u4e8b\u4ef6\u7684\u5904\u7406\u5668<\/strong>\u3002\u4f8b\u5982\u4e0b\u9762\u7684\u4ee3\u7801\u6240\u793a\uff0c\u6307\u5b9a\u4e86\u4e00\u4e2a <code>show<\/code> \u65b9\u6cd5\u4f5c\u4e3a <code>click<\/code> \u4e8b\u4ef6\u7684\u5904\u7406\u5668\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;button @click=&quot;show&quot;&gt;\u6309\u94ae&lt;\/button&gt;<\/code><\/pre>\n<p><code>show<\/code> \u65b9\u6cd5\u4f5c\u4e3a<strong>\u4e8b\u4ef6\u5904\u7406\u5668<\/strong>\uff0c\u9700\u8981\u5b9a\u4e49\u5728 <code>methods<\/code> \u8282\u70b9\u4e0b\uff0c\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {}\n  },\n  methods: {\n    show(event) { \n      console.log(&#039;ok&#039;)\n      console.log(event.target.tagName)\n    }\n  }\n})<\/code><\/pre>\n<p>\u5728\u65b9\u6cd5\u4e8b\u4ef6\u5904\u7406\u5668\u7684<strong>\u53c2\u6570\u5217\u8868\u4e2d<\/strong>\uff0c\u7b2c\u4e00\u4e2a\u5f62\u53c2 <code>event<\/code> \u662f<strong>\u4e8b\u4ef6\u5bf9\u8c61<\/strong>\u3002<\/p>\n<h4>3. \u57fa\u4e8e\u65b9\u6cd5\u4e8b\u4ef6\u5904\u7406\u5668\u5b9e\u73b0\u6570\u503c\u81ea\u589e<\/h4>\n<ol>\n<li>\n<p>\u58f0\u660e\u6a21\u677f\u7ed3\u6784\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;p&gt;count\u7684\u503c\u4e3a\uff1a{{ count }}&lt;\/p&gt;\n&lt;button @click=&quot;add&quot;&gt;+1&lt;\/button&gt;<\/code><\/pre>\n<\/li>\n<li>\n<p>\u5728 data \u4e2d\u58f0\u660e\u6570\u636e\u6e90 <code>count<\/code>\uff0c\u5728 methods \u4e2d\u58f0\u660e\u4e8b\u4ef6\u5904\u7406\u5668 <code>add<\/code>\uff0c\u4ee3\u7801\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n data() {\n   return {\n     count: 0\n   }\n },\n methods: {\n   add() {\n     app._instance.proxy.count++\n   }\n }\n})<\/code><\/pre>\n<blockquote>\n<p>\u6ce8\u610f\uff1amethods \u8282\u70b9\u4e0b\u7684\u65b9\u6cd5\u4e2d\uff0c<strong>this<\/strong> \u6307\u5411\u7684\u5c31\u662f <strong>app._instance.proxy<\/strong>\u3002\u6240\u4ee5\u4e0a\u8ff0\u4ee3\u7801\u5b8c\u5168\u53ef\u4ee5\u66ff\u6362\u4e3a <strong>this.count++<\/strong><\/p>\n<\/blockquote>\n<\/li>\n<\/ol>\n<h4>4. \u5185\u8054\u4e8b\u4ef6\u5904\u7406\u5668<\/h4>\n<p>\u5185\u8054\u4e8b\u4ef6\u5904\u7406\u5668\u76f8\u5f53\u4e8e<strong>\u539f\u751f DOM \u4e2d\u7684\u5185\u8054 JavaScript<\/strong>\uff0c\u4f8b\u5982\u6570\u503c\u81ea\u589e\u7684\u64cd\u4f5c\uff0c\u53ef\u4ee5\u7b80\u5199\u6210\u5185\u8054\u4e8b\u4ef6\u5904\u7406\u5668\u7684\u5f62\u5f0f\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;p&gt;count\u7684\u503c\u4e3a\uff1a{{ count }}&lt;\/p&gt;\n&lt;button @click=&quot;count++&quot;&gt;+1&lt;\/button&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      count: 0\n    }\n  }\n})<\/code><\/pre>\n<blockquote>\n<p>\u6ce8\u610f\uff1a\u5185\u8054\u4e8b\u4ef6\u5904\u7406\u5668\u901a\u5e38\u7528\u4e8e<strong>\u7b80\u5355\u7684\u4e1a\u52a1\u573a\u666f<\/strong>\uff0c\u5982\u679c\u6d89\u53ca\u5230\u590d\u6742\u7684\u4e1a\u52a1\u903b\u8f91\uff0c\u8bf7\u4f7f\u7528<strong>\u65b9\u6cd5\u4e8b\u4ef6\u5904\u7406\u5668<\/strong>\u6216<strong>\u5728\u5185\u8054\u5904\u7406\u5668\u4e2d\u8c03\u7528\u65b9\u6cd5<\/strong>\u3002<\/p>\n<\/blockquote>\n<h4>5. \u5728\u5185\u8054\u5904\u7406\u5668\u4e2d\u8c03\u7528\u65b9\u6cd5<\/h4>\n<p>\u9996\u5148\uff0c\u6211\u4eec\u8981\u80fd\u591f\u660e\u786e\u7684\u533a\u5206\u5f00<strong>\u65b9\u6cd5\u4e8b\u4ef6\u5904\u7406\u5668<\/strong>\u548c<strong>\u5185\u8054\u4e8b\u4ef6\u5904\u7406\u5668<\/strong>\u3002<\/p>\n<p>\u5982\u679c\u4e8b\u4ef6\u7ed1\u5b9a\u7684\u5904\u7406\u5668\u662f\u4e2a\u7eaf\u7cb9\u7684<strong>\u65b9\u6cd5\u540d<\/strong>\uff0c\u5219\u662f<strong>\u65b9\u6cd5\u4e8b\u4ef6\u5904\u7406\u5668<\/strong>\uff0c\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;button @click=&quot;show&quot;&gt;\u6309\u94aeA&lt;\/button&gt;<\/code><\/pre>\n<p>\u9664\u6b64\u4e4b\u5916\uff0c\u5176\u5b83\u7ed1\u5b9a\u4e8b\u4ef6\u5904\u7406\u5668\u7684\u5f62\u5f0f\uff0c\u90fd\u662f<strong>\u5185\u8054\u4e8b\u4ef6\u5904\u7406\u5668<\/strong>\uff0c\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;!-- \u7ed1\u5b9a\u5185\u8054\u7684 JavaScript --&gt;\n&lt;button @click=&quot;count++&quot;&gt;\u6309\u94aeC&lt;\/button&gt;\n\n&lt;!-- \u7ed1\u5b9a\u4e86\u4e00\u4e2a\u65b9\u6cd5\u7684\u8c03\u7528 --&gt;\n&lt;button @click=&quot;show()&quot;&gt;\u6309\u94aeB&lt;\/button&gt;\n\n&lt;!-- \u7ed1\u5b9a\u4e86\u65b9\u6cd5\u7684\u8c03\u7528\u7684\u540c\u65f6\uff0c\u4f20\u9012\u53c2\u6570 --&gt;\n&lt;button @click=&quot;show(&#039;Hello world.&#039;)&quot;&gt;\u6309\u94aeB&lt;\/button&gt;<\/code><\/pre>\n<blockquote>\n<p>\u5185\u8054\u4e8b\u4ef6\u5904\u7406\u5668\u7684<strong>\u4f18\u70b9<\/strong>\uff1a\u89e3\u9501\u4e86\u6a21\u677f\u5411\u5904\u7406\u5668\u65b9\u6cd5\u4f20\u9012\u53c2\u6570\u7684\u80fd\u529b\u3002<\/p>\n<\/blockquote>\n<h4>6. \u5728\u5185\u8054\u4e8b\u4ef6\u5904\u7406\u5668\u4e2d\u8bbf\u95ee\u4e8b\u4ef6\u5bf9\u8c61<\/h4>\n<blockquote>\n<p>\u5185\u8054\u4e8b\u4ef6\u5904\u7406\u5668\u7684<strong>\u7f3a\u70b9<\/strong>\uff1a\u4e8b\u4ef6\u5bf9\u8c61\u4e22\u5931\u4e86\uff0c\u65e0\u6cd5\u5728\u5904\u7406\u5668\u65b9\u6cd5\u4e2d\u8bbf\u95ee\u5230\u4e8b\u4ef6\u5bf9\u8c61 event\u3002<\/p>\n<\/blockquote>\n<p>\u4e0a\u8ff0\u95ee\u9898\u7684\u89e3\u51b3\u65b9\u6848\u6709\u4e24\u4e2a\uff0c\u5206\u522b\u662f\uff1a<\/p>\n<ul>\n<li>\n<p>\u4f7f\u7528\u7279\u6b8a\u7684 $event \u53d8\u91cf<\/p>\n<\/li>\n<li>\n<p>\u4f7f\u7528\u5185\u8054\u7bad\u5934\u51fd\u6570\u63a5\u6536\u5e76\u4f20\u9012 event \u5bf9\u8c61<\/p>\n<\/li>\n<\/ul>\n<p><strong>\u89e3\u51b3\u65b9\u68481<\/strong>\uff1a\u4f7f\u7528\u7279\u6b8a\u7684 $event \u53d8\u91cf<\/p>\n<pre><code class=\"language-html\">&lt;button @click=&quot;showMsg(&#039;hello world.&#039;, $event)&quot;&gt;\u6309\u94ae&lt;\/button&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684 <code>showMsg<\/code> \u5904\u7406\u5668\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  methods: {\n    showMsg(msg, event) {\n      \/\/ \u6539\u53d8\u6309\u94ae\u663e\u793a\u7684\u6587\u672c\n      event.target.innerHTML = msg\n      \/\/ \u6539\u53d8\u6309\u94ae\u7684\u80cc\u666f\u989c\u8272\n      event.target.style.backgroundColor = &#039;cyan&#039;\n    }\n  }\n})<\/code><\/pre>\n<p><strong>\u89e3\u51b3\u65b9\u68482<\/strong>\uff1a\u4f7f\u7528\u5185\u8054\u7bad\u5934\u51fd\u6570\u63a5\u6536\u5e76\u4f20\u9012 event \u5bf9\u8c61<\/p>\n<pre><code class=\"language-html\">&lt;button @click=&quot;(event) =&gt; showMsg(&#039;\u4f60\u597d\uff0c\u4e16\u754c\u3002&#039;, event)&quot;&gt;\u6309\u94ae&lt;\/button&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684 <code>showMsg<\/code> \u5904\u7406\u5668\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  methods: {\n    showMsg(msg, event) {\n      \/\/ \u6539\u53d8\u6309\u94ae\u663e\u793a\u7684\u6587\u672c\n      event.target.innerHTML = msg\n      \/\/ \u6539\u53d8\u6309\u94ae\u7684\u80cc\u666f\u989c\u8272\n      event.target.style.backgroundColor = &#039;cyan&#039;\n    }\n  }\n})<\/code><\/pre>\n<h4>7. \u4e8b\u4ef6\u4fee\u9970\u7b26<\/h4>\n<p>\u5728\u539f\u751f DOM \u7684\u4e8b\u4ef6\u5904\u7406\u51fd\u6570\u4e2d\uff0c\u5982\u679c\u60f3\u8981\u963b\u6b62\u5192\u6ce1\u884c\u4e3a\uff0c\u5219\u9700\u8981\u8c03\u7528 <code>event.stopPropagation()<\/code>\uff1b\u5982\u679c\u60f3\u8981\u963b\u6b62\u9ed8\u8ba4\u884c\u4e3a\uff0c\u5219\u9700\u8981\u8c03\u7528 <code>event.preventDefault()<\/code>\u3002\u4e3a\u4e86\u63d0\u9ad8\u7528\u6237\u7684\u5f00\u53d1\u4f53\u9a8c\uff0cvue \u63d0\u4f9b\u4e86\u66f4\u4f18\u96c5\u7684\u65b9\u5f0f\u6765\u963b\u6b62\u4e8b\u4ef6\u5192\u6ce1\u6216\u9ed8\u8ba4\u884c\u4e3a\uff0c\u5373\uff1a\u4e8b\u4ef6\u4fee\u9970\u7b26\u3002<\/p>\n<p>\u5728 vue \u4e2d\u6700\u5e38\u7528\u7684\u4e24\u4e2a\u4e8b\u4ef6\u4fee\u9970\u7b26\u5206\u522b\u662f\uff1a<\/p>\n<ul>\n<li>.prevent<\/li>\n<li>.stop<\/li>\n<\/ul>\n<p>\u5176\u4e2d <code>.prevnet<\/code> \u7528\u6765<strong>\u963b\u6b62\u9ed8\u8ba4\u884c\u4e3a<\/strong>\uff0c\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;!-- \u4f7f\u7528 .prevent \u4fee\u9970\u4e86 a \u94fe\u63a5\u7684 click \u4e8b\u4ef6 --&gt;\n&lt;!-- \u70b9\u51fb\u8d85\u94fe\u63a5\u540e\uff0c\u4f1a\u963b\u6b62\u8d85\u94fe\u63a5\u7684\u9ed8\u8ba4\u8df3\u8f6c\u884c\u4e3a --&gt;\n&lt;a href=&quot;https:\/\/www.escook.cn\/&quot; @click.prevent=&quot;showMsg&quot;&gt;\u8d85\u94fe\u63a5&lt;\/a&gt;<\/code><\/pre>\n<p>\u53e6\u5916 <code>.stop<\/code> \u7528\u6765\u963b\u6b62\u4e8b\u4ef6\u5192\u6ce1\uff0c\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div @click=&quot;outerHandler&quot;&gt;\n  &lt;!-- \u70b9\u51fb\u5185\u90e8\u7684 button \u6309\u94ae\uff0cclick \u4e8b\u4ef6\u4e0d\u4f1a\u5411\u5916\u5192\u6ce1 --&gt;\n  &lt;!-- \u6240\u4ee5\u5916\u5c42\u7684 outerHandler \u5904\u7406\u5668\u4e0d\u4f1a\u6267\u884c --&gt;\n  &lt;button @click.stop=&quot;innerHandler&quot;&gt;\u6309\u94ae&lt;\/button&gt;\n&lt;\/div&gt;<\/code><\/pre>\n<blockquote>\n<p>\u62d3\u5c55\uff1a\u5176\u5b83\u4e8b\u4ef6\u4fee\u9970\u7b26\u8fd8\u6709 .self\u3001.capture\u3001.once\u3001.passive\u3002\u5177\u4f53\u7528\u6cd5\u8bf7\u53c2\u8003 <a href=\"https:\/\/cn.vuejs.org\/guide\/essentials\/event-handling.html#event-modifiers\">vue3 \u5b98\u65b9\u6587\u6863 &#8211; \u4e8b\u4ef6\u4fee\u9970\u7b26<\/a>\u3002<\/p>\n<\/blockquote>\n<h4>8. \u6309\u952e\u4fee\u9970\u7b26<\/h4>\n<p>\u5728\u76d1\u542c\u952e\u76d8\u4e8b\u4ef6\u65f6\uff0c\u6211\u4eec\u7ecf\u5e38\u9700\u8981\u68c0\u67e5\u7279\u5b9a\u7684\u6309\u952e\uff0c\u4ece\u800c\u6267\u884c\u7279\u5b9a\u7684\u64cd\u4f5c\u3002\u4f8b\u5982\uff1a<\/p>\n<ul>\n<li>\u7528\u6237\u5728\u8f93\u5165\u6846\u4e2d\u6309\u4e0b\u4e86 <strong>enter<\/strong> \u952e\uff0c\u5219\u89e6\u53d1\u63d0\u4ea4\u7684\u51fd\u6570<\/li>\n<li>\u7528\u6237\u5728\u8f93\u5165\u6846\u4e2d\u6309\u4e0b\u4e86 <strong>esc<\/strong> \u952e\uff0c\u5219\u6e05\u7a7a\u6587\u672c\u6846\u7684\u5185\u5bb9<\/li>\n<\/ul>\n<p>\u793a\u4f8b\u4ee3\u7801\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;input type=&quot;text&quot; v-model=&quot;msg&quot; @keyup.enter=&quot;submit&quot; @keyup.esc=&quot;clear&quot;&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684 JS \u5904\u7406\u903b\u8f91\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      msg: &#039;&#039; \/\/ \u6587\u672c\u6846\u7684\u6570\u636e\n    }\n  },\n  methods: {\n    \/\/ \u8be5\u5904\u7406\u51fd\u6570\u4ec5\u5728\u7528\u6237\u6309\u4e0b enter \u952e\u65f6\u89e6\u53d1\n    submit() {\n      console.log(&#039;\u63d0\u4ea4\u7684\u6570\u636e\u4e3a\uff1a&#039; + this.msg)\n    },\n    \/\/ \u8be5\u5904\u7406\u51fd\u6570\u4ec5\u5728\u7528\u6237\u6309\u4e0b esc \u952e\u65f6\u89e6\u53d1\n    clear() {\n      this.msg = &#039;&#039;\n    }\n  }\n})<\/code><\/pre>\n<h4>9. \u6309\u952e\u522b\u540d\u4e0e\u6309\u952e\u540d\u7684\u83b7\u53d6<\/h4>\n<p>vue \u4e3a<strong>\u5e38\u7528\u7684\u6309\u952e<\/strong>\u63d0\u4f9b\u4e86<strong>\u5b98\u65b9\u5185\u7f6e\u7684\u6309\u952e\u522b\u540d<\/strong>\uff0c\u5217\u8868\u5982\u4e0b\uff1a<\/p>\n<ul>\n<li>.enter<\/li>\n<li>.tab<\/li>\n<li>.delete (\u6355\u83b7\u201cDelete\u201d\u548c\u201cBackspace\u201d\u4e24\u4e2a\u6309\u952e)<\/li>\n<li>.esc<\/li>\n<li>.space<\/li>\n<li>.up<\/li>\n<li>.down<\/li>\n<li>.left<\/li>\n<li>.right<\/li>\n<\/ul>\n<p>\u5982\u679c\u4e0a\u8ff0\u5217\u8868\u4e2d\u6ca1\u6709\u4f60\u60f3\u76d1\u542c\u7684\u6309\u952e\uff0c\u5219\u53ef\u4ee5\u4f7f\u7528 <code>$event.key<\/code> \u5148\u83b7\u53d6\u6309\u952e\u7684\u540d\u79f0\uff0c\u518d\u628a\u83b7\u53d6\u5230\u7684\u6309\u952e\u540d\u79f0\u8f6c\u4e3a kebab-case \u5f62\u5f0f\uff0c\u6700\u540e\u5229\u7528\u8f6c\u6362\u5f97\u5230\u7684\u6309\u952e\u540d\u8fdb\u884c\u76d1\u542c\u5373\u53ef\uff0c\u4f8b\u5982\u4e0b\u9762\u7684\u4ee3\u7801\u76d1\u542c\u4e86 <strong>CapsLock<\/strong> \u6309\u952e\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;p&gt;\u8f93\u5165\u72b6\u6001\uff1a{{ isUpperCase ? &#039;\u5927\u5199&#039; : &#039;\u5c0f\u5199&#039; }}&lt;\/p&gt;\n&lt;input type=&quot;text&quot; v-model=&quot;msg&quot; @keyup.caps-lock=&quot;changeMode&quot;&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684 JS \u903b\u8f91\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      msg: &#039;&#039;, \/\/ \u6587\u672c\u6846\u7684\u6570\u636e\n      isUpperCase: false \/\/ \u662f\u5426\u4e3a\u5927\u5199\u8f93\u5165\u6a21\u5f0f\n    }\n  },\n  methods: {\n    \/\/ \u4ec5\u5f53\u7528\u6237\u6309\u4e0b\u7684\u662f CapsLock \u952e\uff0c\u624d\u89e6\u53d1\u6b64\u51fd\u6570\u7684\u6267\u884c\n    changeMode() {\n      this.isUpperCase = !this.isUpperCase\n    }\n  }\n})<\/code><\/pre>\n<h4>10. \u7cfb\u7edf\u6309\u952e\u4fee\u9970\u7b26<\/h4>\n<p>\u5982\u679c\u5728\u89e6\u53d1\u4e8b\u4ef6\u7684\u65f6\u5019\uff0c\u60f3\u8981\u5224\u65ad\u7528\u6237\u662f\u5426\u540c\u65f6\u6309\u4e0b\u4e86 Ctrl\u3001Alt \u7b49\u7cfb\u7edf\u6309\u952e\u3002\u6b64\u65f6\u53ef\u4ee5\u4f7f\u7528 vue \u5185\u7f6e\u7684\u7cfb\u7edf\u6309\u952e\u4fee\u9970\u7b26\uff0c\u4e3b\u8981\u6709\u4ee5\u4e0b4\u4e2a\uff1a<\/p>\n<ul>\n<li>.ctrl<\/li>\n<li>.alt<\/li>\n<li>.shift<\/li>\n<li>.meta [\u6ce8\u610f\uff1ameta \u5728 Windows \u952e\u76d8\u4e0a\u6307\u7684\u662f <strong>Windows \u952e<\/strong>(\u229e)\uff0c\u5728 Mac \u952e\u76d8\u4e0a\u6307\u7684\u662f <strong>Command \u952e<\/strong>(\u2318)]<\/li>\n<\/ul>\n<p>\u4f8b\u5982\uff0c\u4e0b\u9762\u7684\u4ee3\u7801\u76d1\u542c\u4e86\u89e6\u53d1 div \u7684 click \u4e8b\u4ef6\u65f6\uff0c\u662f\u5426\u540c\u65f6\u6309\u4e0b\u4e86\u7279\u5b9a\u7684\u7cfb\u7edf\u6309\u952e\uff0c\u4ece\u800c\u6539\u53d8 div \u7684\u5f62\u72b6\u548c\u5916\u89c2\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;!-- \u70b9\u51fb div \u7684\u65f6\u5019\uff0c --&gt;\n&lt;!-- 1. \u5982\u679c\u540c\u65f6\u6309\u4e0b\u4e86 Ctrl \u952e\uff0c\u5219\u6dfb\u52a0 square \u7c7b\u6837\u5f0f --&gt;\n&lt;!-- 2. \u5982\u679c\u540c\u65f6\u6309\u4e0b\u4e86 Alt \u952e\uff0c\u5219\u6dfb\u52a0 round \u7c7b\u6837\u5f0f --&gt;\n&lt;!-- 3. \u5982\u679c\u540c\u65f6\u6309\u4e0b\u4e86 Shift \u952e\uff0c\u5219\u8fd8\u539f\u4e3a\u9ed8\u8ba4\u7684 box \u7c7b\u6837\u5f0f --&gt;\n&lt;div class=&quot;box&quot; :class=&quot;shape&quot;\n     @click.ctrl=&quot;changeShape(&#039;square&#039;)&quot;\n     @click.alt=&quot;changeShape(&#039;round&#039;)&quot;\n     @click.shift=&quot;changeShape(&#039;&#039;)&quot;&gt;\n&lt;\/div&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684 JS \u903b\u8f91\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      \/\/ \u7c7b\u6837\u5f0f\u7684\u540d\u79f0\n      shape: &#039;&#039;\n    }\n  },\n  methods: {\n    \/\/ \u4e8b\u4ef6\u7684\u5904\u7406\u51fd\u6570\n    changeShape(shape) {\n      this.shape = shape\n    }\n  }\n})<\/code><\/pre>\n<p>\u914d\u5957\u7684 CSS \u6837\u5f0f\u4e3a\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;style&gt;\n  .box {\n    width: 300px;\n    height: 300px;\n    background-color: #efefef;\n    transition: all 1s ease;\n  }\n\n  .square {\n    border-radius: 20px;\n    background-color: cyan;\n    transition: all 1s ease;\n  }\n\n  .round {\n    border-radius: 50%;\n    background-color: lightgreen;\n    transition: all 1s ease;\n  }\n&lt;\/style&gt;<\/code><\/pre>\n<h4>11. <code>.exact<\/code> \u4fee\u9970\u7b26<\/h4>\n<p>\u4e0a\u8ff0\u7684\u4f8b\u5b50\u4e2d\uff0c\u5b58\u5728\u4e00\u4e2a\u5f88\u660e\u663e\u7684 Bug\uff1a<\/p>\n<ul>\n<li>\u6211\u4eec\u5e0c\u671b\u5728\u89e6\u53d1 div \u7684 click \u4e8b\u4ef6\u65f6\uff0c\u4ec5\u5f53\u7528\u6237\u6309\u4e0b\u4e86 <code>Ctrl<\/code> \u6216 <code>Alt<\/code> \u6216 <code>Shift<\/code> \u6309\u952e\u65f6\uff0c\u624d\u89e6\u53d1 <code>changeShape<\/code> \u51fd\u6570<\/li>\n<li>\u73b0\u5728\u7684 Bug \u662f\uff0c\u7528\u6237\u5728\u89e6\u53d1 click \u4e8b\u4ef6\u65f6\uff0c\u5982\u679c\u6309\u4e0b\u4e86 <code>Ctrl + Alt<\/code> \u7684\u7ec4\u5408\u6309\u952e\uff0c\u4e5f\u4f1a\u89e6\u53d1 <code>changeShape<\/code> \u51fd\u6570<\/li>\n<\/ul>\n<p>\u800c <code>.exact<\/code> \u4fee\u9970\u7b26\u53ef\u4ee5\u5b8c\u7f8e\u7684\u89e3\u51b3\u8fd9\u4e2a\u95ee\u9898\u3002<code>.exact<\/code> \u4fee\u9970\u7b26\u8868\u793a<strong>\u7cbe\u786e\u5339\u914d<\/strong>\u7cfb\u7edf\u6309\u952e\u3002<\/p>\n<p>\u56e0\u6b64\uff0c\u6211\u4eec\u53ef\u4ee5\u9488\u5bf9\u4e0a\u8ff0\u7684\u4f8b\u5b50\u8fdb\u884c\u4fee\u6539\uff0c\u5728\u7279\u5b9a\u7684\u7cfb\u7edf\u6309\u952e\u4fee\u9970\u7b26\u7684\u540e\u9762\u5e94\u7528 <code>.exact<\/code> \u4fee\u9970\u7b26\uff0c\u8868\u793a\u7cbe\u786e\u5339\u914d\u7cfb\u7edf\u6309\u952e\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div class=&quot;box&quot; :class=&quot;shape&quot; \n     @click.ctrl.exact=&quot;changeShape(&#039;square&#039;)&quot; \n     @click.alt.exact=&quot;changeShape(&#039;round&#039;)&quot;\n     @click.shift.exact=&quot;changeShape(&#039;&#039;)&quot;&gt;\n&lt;\/div&gt;<\/code><\/pre>\n<blockquote>\n<p>\u6ce8\u610f\uff1a\u6240\u8c13\u7684\u7cbe\u786e\u5339\u914d\u7cfb\u7edf\u6309\u952e\uff0c<strong>\u4ec5\u5bf9\u7cfb\u7edf\u6309\u952e\u4fee\u9970\u7b26\u751f\u6548<\/strong>\uff0c\u5982\u679c\u7528\u6237\u6309\u4e0b\u4e86 Ctrl + A \u7684\u7ec4\u5408\u952e\uff0c\u4e5f\u4f1a\u89e6\u53d1 <code>@click.ctrl.exact<\/code> \u6240\u7ed1\u5b9a\u7684\u4e8b\u4ef6\u5904\u7406\u5668\u3002<\/p>\n<\/blockquote>\n<h4>12. \u9f20\u6807\u6309\u952e\u4fee\u9970\u7b26<\/h4>\n<p>vue \u8fd8\u63d0\u4f9b\u4e86\u9f20\u6807\u6309\u952e\u4fee\u9970\u7b26\uff0c\u7528\u6765\u76d1\u542c\u4e8b\u4ef6\u662f\u5426\u7531\u7279\u5b9a\u7684\u9f20\u6807\u6309\u952e\u89e6\u53d1\uff1a<\/p>\n<ul>\n<li>.left<\/li>\n<li>.right<\/li>\n<li>.middle<\/li>\n<\/ul>\n<p>\u4f8b\u5982\uff0c\u4e0b\u9762\u7684\u4ee3\u7801\u6f14\u793a\u4e86\u5982\u4f55<strong>\u963b\u6b62<\/strong>\u5728 <code>h1<\/code> \u5143\u7d20\u4e0a<strong>\u663e\u793a\u9f20\u6807\u7684\u53f3\u952e\u83dc\u5355<\/strong>\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;h1 @click.right.prevent&gt;\u8fd9\u662f\u4e00\u4e2a\u6807\u9898&lt;\/h1&gt;<\/code><\/pre>\n<blockquote>\n<p>\u6ce8\u610f\uff1a\u7ed1\u5b9a\u4e8b\u4ef6\u65f6\uff0c<strong>\u4e0d\u4e00\u5b9a\u975e\u8981\u63d0\u4f9b\u4e8b\u4ef6\u7684\u5904\u7406\u5668<\/strong>\uff0c\u6211\u4eec\u4e5f\u53ef<strong>\u53ea\u63d0\u4f9b\u4e8b\u4ef6\u4fee\u9970\u7b26<\/strong>\uff0c\u4ece\u800c\u8fbe\u5230\u7279\u5b9a\u7684\u76ee\u7684\u3002<\/p>\n<\/blockquote>\n<h3>3.6 \u5217\u8868\u6e32\u67d3\u6307\u4ee4<\/h3>\n<p><code>v-for<\/code> \u6307\u4ee4\u662f vue \u63d0\u4f9b\u7684\u5217\u8868\u6e32\u67d3\u6307\u4ee4\u3002<\/p>\n<p>\u5982\u679c\u60a8\u6709\u4e00\u4e2a\u6570\u7ec4\uff0c\u60f3\u628a\u6570\u7ec4\u4e2d\u7684\u6bcf\u4e00\u9879\u6e32\u67d3\u4e3a\u683c\u5f0f\u76f8\u4f3c\u7684 HTML \u7ed3\u6784\uff0c\u90a3\u4e48 v-for \u6307\u4ee4\u53ef\u4ee5\u5e2e\u52a9\u60a8\u5b9e\u73b0\u5217\u8868\u6570\u636e\u7684\u6e32\u67d3\u3002<\/p>\n<p>\u4f7f\u7528\u573a\u666f\uff1a\u5546\u54c1\u5217\u8868\u3001\u7528\u6237\u5217\u8868\u7b49\u3002<\/p>\n<h4>1. v-for \u7684\u57fa\u672c\u4f7f\u7528<\/h4>\n<p>v-for \u7684\u57fa\u672c\u8bed\u6cd5\u683c\u5f0f\u4e3a\uff1a<\/p>\n<pre><code class=\"language-html\">v-for=&quot;\u5f53\u524d\u5faa\u73af\u9879 in \u6570\u7ec4&quot;<\/code><\/pre>\n<p>\u5176\u4e2d\u5173\u952e\u5b57 <code>in<\/code> \u524d\u9762\u7684\u662f<strong>\u5f53\u524d\u5faa\u73af\u9879<\/strong>\uff0c\u5173\u952e\u5b57 <code>in<\/code> \u540e\u9762\u7684\u8981\u5faa\u73af\u7684<strong>\u6570\u7ec4<\/strong>\u3002\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;ul&gt;\n  &lt;li v-for=&quot;item in list&quot;&gt;\u59d3\u540d\uff1a{{ item.name }}\uff0c\u5e74\u9f84\uff1a{{ item.age }}&lt;\/li&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      \/\/ \u6570\u7ec4\n      list: [\n        { name: &#039;zs&#039;, age: 20 },\n        { name: &#039;liulongbin&#039;, age: 21 },\n        { name: &#039;escook&#039;, age: 22 }\n      ]\n    }\n  }\n})<\/code><\/pre>\n<h4>2. v-for \u4e2d\u7684\u7d22\u5f15<\/h4>\n<p>v-for \u7684\u5b8c\u6574\u8bed\u6cd5\u683c\u5f0f\u4e3a\uff1a<\/p>\n<pre><code class=\"language-html\">v-for=&quot;(\u5faa\u73af\u9879, \u5faa\u73af\u9879\u7684\u7d22\u5f15) in \u6570\u7ec4&quot;<\/code><\/pre>\n<p>\u5176\u4e2d <code>in<\/code> \u5173\u952e\u5b57\u5de6\u4fa7\u7684 <code>( )<\/code> \u91cc\u9762\uff0c\u5206\u522b\u662f<strong>\u5f53\u524d\u5faa\u73af\u9879<\/strong>\u548c<strong>\u5f53\u524d\u5faa\u73af\u9879\u7684\u7d22\u5f15<\/strong>\u3002\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;ul&gt;\n  &lt;li v-for=&quot;(item, index) in goods&quot;&gt;{{ index + 1 }}. {{ item }}&lt;\/li&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      \/\/ \u6570\u7ec4\n      goods: [&#039;\u624b\u8868&#039;, &#039;\u624b\u673a&#039;, &#039;\u624b\u4e32&#039;]\n    }\n  }\n})<\/code><\/pre>\n<blockquote>\n<p>\u6ce8\u610f\uff1av-for \u4e2d\u7684\u7d22\u4ece 0 \u5f00\u59cb\u9012\u589e\u3002<\/p>\n<\/blockquote>\n<h4>3. v-for \u4e2d\u7684\u89e3\u6784<\/h4>\n<p>\u5982\u679c <code>v-for<\/code> \u6307\u4ee4\u4e2d\u7684\u5faa\u73af\u9879 item \u662f\u4e00\u4e2a\u5bf9\u8c61\uff0c\u5219\u53ef\u4ee5\u5728 v-for \u6307\u4ee4\u4e2d\u8fdb\u884c\u89e3\u6784\u64cd\u4f5c\uff0c\u8bed\u6cd5\u683c\u5f0f\u4e3a\uff1a<\/p>\n<pre><code class=\"language-html\">v-for=&quot;{\u6570\u636eA, \u6570\u636eB} in \u6570\u7ec4&quot;\n\u6216\nv-for=&quot;({\u6570\u636eA, \u6570\u636eB}, \u7d22\u5f15) in \u6570\u7ec4&quot;<\/code><\/pre>\n<p>\u5176\u4e2d <code>in<\/code> \u5173\u952e\u5b57\u5de6\u4fa7\u7684 <code>{ }<\/code> \u8868\u793a\u89e3\u6784\u64cd\u4f5c\u3002\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;ul&gt;\n  &lt;li v-for=&quot;{name, age} in list&quot;&gt;\u59d3\u540d\uff1a{{ name }}\uff0c\u5e74\u9f84\uff1a{{ age }}&lt;\/li&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      \/\/ \u6570\u7ec4\n      list: [\n        { name: &#039;zs&#039;, age: 20 },\n        { name: &#039;liulongbin&#039;, age: 21 },\n        { name: &#039;escook&#039;, age: 22 }\n      ]\n    }\n  }\n})<\/code><\/pre>\n<h4>4. template \u4e0a\u7684 v-for<\/h4>\n<p><code>v-for<\/code> \u6307\u4ee4\u6bcf\u6b21\u53ea\u80fd\u5faa\u73af\u751f\u6210\u4e00\u4e2a\u5143\u7d20\uff0c\u5982\u679c\u60f3\u5728\u6bcf\u6b21\u5faa\u73af\u671f\u95f4<strong>\u751f\u6210\u4e00\u7ec4\u5143\u7d20<\/strong>\uff0c\u5219\u5fc5\u987b\u5728\u8fd9\u4e00\u7ec4\u5143\u7d20\u4e4b\u5916<strong>\u5305\u88f9\u4e00\u5c42 div \u6807\u7b7e\u4f5c\u4e3a\u5bb9\u5668<\/strong>\uff0c\u5e76\u628a <code>v-for<\/code> \u6307\u4ee4\u4f5c\u7528\u4e8e\u5916\u5c42\u7684 div \u5bb9\u5668\u4e4b\u4e0a\u3002\u4f8b\u5982\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;ul&gt;\n  &lt;div v-for=&quot;(item, index) in list&quot;&gt;\n    &lt;li class=&quot;divider&quot; v-if=&quot;index!== 0&quot;&gt;&lt;\/li&gt;\n    &lt;li&gt;\u59d3\u540d\uff1a{{ item.name }}\uff0c\u5e74\u9f84\uff1a{{ item.age }}&lt;\/li&gt;\n  &lt;\/div&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684 css \u6837\u5f0f\u4e3a\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;style&gt;\n  .divider {\n    border-top: 1px solid #888;\n    list-style: none;\n    margin: 10px 0;\n  }\n&lt;\/style&gt;<\/code><\/pre>\n<p>\u5982\u4e0a\uff0c\u867d\u7136\u53ef\u4ee5\u5b9e\u73b0\u5217\u8868\u6570\u636e\u7684\u6e32\u67d3\uff0c\u4f46\u5374\u4e0d\u5c3d\u5b8c\u7f8e\u3002\u56e0\u4e3a <code>div<\/code> \u6807\u7b7e\u5728\u5faa\u73af\u4e2d\u53ea\u8d77\u5230\u5bb9\u5668\u7684\u4f5c\u7528\uff0c\u5728\u6574\u4e2a\u5217\u8868\u7ed3\u6784\u4e2d\u6ca1\u6709\u4efb\u4f55\u610f\u4e49\u3002<\/p>\n<p>\u6240\u4ee5\u63a8\u8350\u7684\u505a\u6cd5\u662f\u5229\u7528 vue \u5185\u7f6e\u7684 <code>&lt;template&gt;<\/code> \u6807\u7b7e\u66ff\u4ee3\u4e0a\u8ff0\u7684 <code>div<\/code> \u6807\u7b7e\uff0c\u56e0\u4e3a <code>&lt;template&gt;<\/code> \u662f\u4e00\u4e2a<strong>\u865a\u62df\u7684\u5bb9\u5668<\/strong>\uff0c<strong>\u4e0d\u4f1a\u88ab\u6e32\u67d3\u4e3a\u5b9e\u9645\u7684\u5143\u7d20<\/strong>\u3002<\/p>\n<p>\u6700\u7ec8\uff0c\u4f18\u5316\u8fc7\u540e\u7684\u4ee3\u7801\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;ul&gt;\n  &lt;template v-for=&quot;(item, index) in list&quot;&gt;\n    &lt;li class=&quot;divider&quot; v-if=&quot;index!== 0&quot;&gt;&lt;\/li&gt;\n    &lt;li&gt;\u59d3\u540d\uff1a{{ item.name }}\uff0c\u5e74\u9f84\uff1a{{ item.age }}&lt;\/li&gt;\n  &lt;\/template&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<blockquote>\n<p>\u601d\u8003\uff1a\u5206\u5272\u7ebf\u7684 &lt;li&gt;\u00a0\u80fd\u5426\u653e\u5728\u6570\u636e\u7684 &lt;li&gt;\u00a0\u4e4b\u540e\uff1f\u5982\u679c\u80fd\uff0c\u5219 v-if \u7684\u6761\u4ef6\u662f\u4ec0\u4e48\uff1f\u5982\u679c\u4e0d\u80fd\uff0c\u8bf7\u8bf4\u51fa\u4e3a\u4ec0\u4e48\u3002<\/p>\n<\/blockquote>\n<h4>5. v-for \u4e0e v-if \u7684\u4f18\u5148\u7ea7<\/h4>\n<blockquote>\n<p>\u6ce8\u610f\uff1avue \u5b98\u65b9<strong>\u4e0d\u63a8\u8350<\/strong>\u5728\u4e00\u4e2a\u5143\u7d20\u4e0a\uff0c\u540c\u65f6\u4f7f\u7528 v-if \u548c v-for \u6307\u4ee4\u3002\u56e0\u4e3a\u8fd9\u6837\u4f7f\u7528<strong>\u65e0\u6cd5\u660e\u786e\u4f53\u73b0\u51fa\u4e8c\u8005\u7684\u4f18\u5148\u7ea7<\/strong>\u3002\u964d\u4f4e\u4ee3\u7801\u7684\u9605\u8bfb\u6027\u548c\u7ef4\u62a4\u6027\u3002<\/p>\n<\/blockquote>\n<p>\u5f53 <code>v-if<\/code> \u548c <code>v-for<\/code> \u540c\u65f6\u5b58\u5728\u4e8e\u4e00\u4e2a\u5143\u7d20\u4e0a\u7684\u65f6\u5019\uff0c<code>v-if<\/code> \u6bd4 <code>v-for<\/code> \u7684\u4f18\u5148\u7ea7\u66f4\u9ad8\u3002\u8fd9\u610f\u5473\u7740 <code>v-if<\/code> \u7684\u6761\u4ef6\u5c06\u65e0\u6cd5\u8bbf\u95ee\u5230 <code>v-for<\/code> \u4f5c\u7528\u57df\u5185\u5b9a\u4e49\u7684\u53d8\u91cf\u522b\u540d\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;ul&gt;\n  &lt;!-- \u6ce8\u610f\uff1a\u8fd9\u91cc\u7684 v-if \u6307\u4ee4\u4e2d\uff0c\u65e0\u6cd5\u8bbf\u95ee\u5230 item.done \u5bf9\u5e94\u7684\u6570\u636e\uff0c --&gt;\n  &lt;!-- \u56e0\u4e3a v-if \u6bd4 v-for \u7684\u4f18\u5148\u7ea7\u9ad8\uff0c --&gt;\n  &lt;!-- \u5f53 v-if \u6267\u884c\u7684\u65f6\u5019\u8bbf\u95ee\u4e0d\u5230 item \u5bf9\u8c61\uff0c\u56e0\u4e3a v-for \u6b64\u65f6\u8fd8\u672a\u6267\u884c\uff01 --&gt;\n  &lt;li v-for=&quot;item in todos&quot; v-if=&quot;!item.done&quot;&gt;{{item.task}}&lt;\/li&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      \/\/ \u4efb\u52a1\u5217\u8868\uff0cdone \u4e3a true \u8868\u793a\u5b8c\u6210\uff1bdone \u4e3a false \u8868\u793a\u672a\u5b8c\u6210\n      todos: [\n        { task: &#039;\u6668\u7ec3&#039;, done: true },\n        { task: &#039;\u5403\u65e9\u9910&#039;, done: true },\n        { task: &#039;\u5403\u5348\u996d&#039;, done: false },\n        { task: &#039;\u5348\u4f11&#039;, done: false }\n      ]\n    }\n  }\n})<\/code><\/pre>\n<p>\u89e3\u51b3\u7684\u65b9\u6848\u5f88\u7b80\u5355\uff0c<strong>\u5148\u5faa\u73af\u518d\u5224\u65ad<\/strong>\u5373\u53ef\u3002\u5728 <code>li<\/code> \u5143\u7d20\u7684\u5916\u5c42\u5305\u88f9\u4e00\u4e2a <code>template<\/code> \u7ec4\u4ef6\uff0c\u5e76\u628a <code>v-for<\/code> \u6307\u4ee4\u4ece <code>li<\/code> \u4e0a\u632a\u5230 <code>template<\/code> \u7ec4\u4ef6\u4e0a\uff0c\u793a\u4f8b\u4ee3\u7801\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;ul&gt;\n  &lt;template v-for=&quot;item in todos&quot;&gt;\n    &lt;li v-if=&quot;!item.done&quot;&gt;{{item.task}}&lt;\/li&gt;\n  &lt;\/template&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u6539\u9020\u540e\u7684\u4ee3\u7801\u9664\u4e86\u89e3\u51b3\u4e86 <code>v-if<\/code> <strong>\u4f18\u5148\u7ea7\u9ad8<\/strong>\u5bfc\u81f4\u7684\u62a5\u9519\u95ee\u9898\u4e4b\u5916\uff0c\u8fd8\u6709\u8fd93\u4e2a\u660e\u663e\u7684\u7279\u5f81\uff1a<\/p>\n<ol>\n<li><code>&lt;template&gt;<\/code> \u662f\u4e00\u4e2a\u865a\u62df\u5bb9\u5668\uff0c\u4e0d\u4f1a\u88ab\u6e32\u67d3\u4e3a\u4efb\u4f55\u5b9e\u9645\u5143\u7d20\uff0c\u56e0\u6b64\u4e0d\u4f1a\u5bfc\u81f4 DOM \u7ed3\u6784\u7684\u5197\u4f59<\/li>\n<li>\u4ee3\u7801\u7684\u53ef\u8bfb\u6027\u66f4\u5f3a\uff0c\u5916\u5c42\u7528\u6765\u5faa\u73af\u6570\u7ec4\u4ece\u800c\u5f97\u5230\u6bcf\u4e2a\u5217\u8868\u9879\uff0c\u5185\u90e8\u6839\u636e\u5217\u8868\u9879\u7684\u72b6\u6001\u5b9e\u73b0 DOM \u7ed3\u6784\u7684\u6309\u9700\u6e32\u67d3<\/li>\n<li>\u5982\u679c <code>item.done<\/code> \u503c\u4e3a <code>false<\/code>\uff0c\u5219\u4e0d\u4f1a\u6e32\u67d3\u5bf9\u5e94\u7684 DOM \u7ed3\u6784\uff0c\u56e0\u6b64\u521d\u59cb\u7684\u6e32\u67d3\u6027\u80fd\u8f83\u597d<\/li>\n<\/ol>\n<h3>3.7 v-for \u4e2d\u7684 key \u7684\u57fa\u672c\u4f7f\u7528<\/h3>\n<p>key \u503c\u662f v-for \u6307\u4ee4\u4e2d\u5f88\u91cd\u8981\u7684\u4e00\u4e2a\u5185\u5bb9\uff0c\u5728\u63a5\u4e0b\u6765\u7684\u8bfe\u7a0b\u4e2d\uff0c\u6211\u4eec\u5148\u6765\u5b66\u4e60 key \u503c\u7684\u57fa\u672c\u4f7f\u7528\uff0c\u7136\u540e\u518d\u6df1\u5165\u63a2\u8ba8\u4e00\u4e0b key \u503c\u7684\u5185\u90e8\u539f\u7406\u3002<\/p>\n<h4>1. \u6848\u4f8b\uff1a\u5728 v-for \u5217\u8868\u7684\u5934\u90e8\u8ffd\u52a0\u5143\u7d20<\/h4>\n<p>\u5728 data \u8282\u70b9\u4e0b\uff0c\u5b9a\u4e49\u4efb\u52a1\u5217\u8868\u7684 <code>todos<\/code> \u6570\u636e\uff1a<\/p>\n<pre><code class=\"language-js\">data() {\n  return {\n    \/\/ \u4efb\u52a1\u5217\u8868\n    todos: [\n      { task: &#039;\u6668\u7ec3&#039; },\n      { task: &#039;\u5403\u65e9\u9910&#039; },\n      { task: &#039;\u5403\u5348\u996d&#039; }\n    ]\n  }\n}<\/code><\/pre>\n<p>\u5e76\u5728\u6a21\u677f\u7ed3\u6784\u4e2d\uff0c\u4f7f\u7528 <code>v-for<\/code> \u6307\u4ee4\u5faa\u73af\u6e32\u67d3\u51fa\u5217\u8868\u7684\u7ed3\u6784\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;!-- \u5217\u8868\u533a\u57df --&gt;\n&lt;ul&gt;\n  &lt;li v-for=&quot;item in todos&quot;&gt;\n    &lt;span&gt;{{ item.task }}&lt;\/span&gt;\n  &lt;\/li&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u4e3a\u4e86\u80fd\u591f\u5b9e\u73b0\u5728\u4efb\u52a1\u5217\u8868\u7684\u5934\u90e8\u6dfb\u52a0\u65b0\u4efb\u52a1\u7684\u529f\u80fd\uff0c\u8fd8\u9700\u8981\u5728 data \u8282\u70b9\u4e0b\u5b9a\u4e49\u540d\u4e3a <code>taskName<\/code> \u7684\u6570\u636e\u9879\uff0c\u8868\u793a\u5373\u5c06\u6dfb\u52a0\u5230\u5934\u90e8\u7684\u65b0\u4efb\u52a1\u7684\u540d\u79f0\uff0c\u540c\u65f6\uff0c\u8fd8\u8981\u5728 methods \u8282\u70b9\u4e0b\u5b9a\u4e49\u540d\u4e3a <code>add<\/code> \u7684\u65b9\u6cd5\uff0c\u7528\u6765\u5f53\u505a\u6dfb\u52a0\u6309\u94ae\u7684 click \u4e8b\u4ef6\u5904\u7406\u5668\uff1a<\/p>\n<pre><code class=\"language-js\">const app = createApp({\n  data() {\n    return {\n      \/\/ \u8981\u6dfb\u52a0\u7684\u4efb\u52a1\u540d\u79f0\n      taskName: &#039;&#039;,\n      \/\/ \u4efb\u52a1\u5217\u8868\n      todos: [\n        { task: &#039;\u6668\u7ec3&#039; },\n        { task: &#039;\u5403\u65e9\u9910&#039; },\n        { task: &#039;\u5403\u5348\u996d&#039; }\n      ]\n    }\n  },\n  methods: {\n    \/\/ \u6dfb\u52a0\u64cd\u4f5c\n    add() {\n      \/\/ 1. \u5982\u679c\u8981\u6dfb\u52a0\u7684\u4efb\u52a1\u540d\u79f0\u4e3a\u7a7a\uff0c\u5219\u63d0\u793a\u8b66\u544a\u4fe1\u606f\n      if (this.taskName.length === 0) return console.warn(&#039;\u4efb\u52a1\u540d\u79f0\u4e0d\u80fd\u4e3a\u7a7a\uff01&#039;)\n      \/\/ 2. \u5411\u5217\u8868\u5934\u90e8\u6dfb\u52a0\u4e00\u4e2a\u65b0\u4efb\u52a1\n      this.todos.unshift({ task: this.taskName })\n      \/\/ 3. \u6e05\u7a7a\u6587\u672c\u6846\u7684\u5185\u5bb9\n      this.taskName = &#039;&#039;\n    }\n  }\n})<\/code><\/pre>\n<p>\u6700\u540e\uff0c\u5728\u6a21\u677f\u7ed3\u6784\u4e2d\uff0c\u65b0\u589e\u6dfb\u52a0\u533a\u57df\u7684 UI \u7ed3\u6784\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div id=&quot;app&quot;&gt;\n\n  &lt;!-- \u6dfb\u52a0\u533a\u57df --&gt;\n  &lt;div&gt;\n    &lt;input type=&quot;text&quot; v-model.trim=&quot;taskName&quot;&gt;\n    &lt;button @click=&quot;add&quot;&gt;\u6dfb\u52a0&lt;\/button&gt;\n  &lt;\/div&gt;\n\n  &lt;hr&gt;\n  &lt;!-- \u5217\u8868\u533a\u57df --&gt;\n  &lt;ul&gt;\n    &lt;li v-for=&quot;item in todos&quot;&gt;\n      &lt;span&gt;{{ item.task }}&lt;\/span&gt;\n    &lt;\/li&gt;\n  &lt;\/ul&gt;\n&lt;\/div&gt;<\/code><\/pre>\n<p>\u81f3\u6b64\uff0c\u5728\u5934\u90e8\u8ffd\u52a0\u65b0\u4efb\u52a1\u7684\u529f\u80fd\u5c31\u5b9e\u73b0\u4e86\uff0c\u7ecf\u8fc7\u6d4b\u8bd5\uff0c\u4ee3\u7801\u6ca1\u6709\u4efb\u4f55\u95ee\u9898\uff0c\u529f\u80fd\u4e5f\u53ef\u4ee5\u6b63\u5e38\u4f7f\u7528\u3002<\/p>\n<h4>2. \u65b0\u529f\u80fd\uff1a\u52fe\u9009\u4efb\u52a1\u7684\u5b8c\u6210\u72b6\u6001<\/h4>\n<p>\u6211\u4eec\u5728\u4e0a\u4e00\u4e2a\u6848\u4f8b\u7684\u57fa\u7840\u4e4b\u4e0a\uff0c\u7ee7\u7eed\u6dfb\u52a0\u4e00\u4e2a<strong>\u52fe\u9009\u4efb\u52a1\u5b8c\u6210\u72b6\u6001<\/strong>\u7684\u65b0\u529f\u80fd\u3002<\/p>\n<p>\u4fee\u6539\u6a21\u677f\u7ed3\u6784\u4e2d\u7684\u5217\u8868\u533a\u57df\uff0c\u5728\u6bcf\u4e2a <code>li<\/code> \u5143\u7d20\u4e2d\uff0c\u90fd\u6dfb\u52a0\u4e00\u4e2a <code>checkbox<\/code> \u590d\u9009\u6846\uff0c\u4f5c\u4e3a\u5f53\u524d\u4efb\u52a1\u7684\u5b8c\u6210\u72b6\u6001\uff0c\u4ee3\u7801\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;!-- \u5217\u8868\u533a\u57df --&gt;\n&lt;ul&gt;\n  &lt;li v-for=&quot;item in todos&quot;&gt;\n    &lt;!-- \u4efb\u52a1\u7684\u5b8c\u6210\u72b6\u6001 --&gt;\n    &lt;input type=&quot;checkbox&quot;&gt;\n    &lt;!-- \u4efb\u52a1\u7684\u540d\u79f0 --&gt;\n    &lt;span&gt;{{ item.task }}&lt;\/span&gt;\n  &lt;\/li&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u6539\u9020\u5b8c\u6210\u540e\u7acb\u5373\u6d4b\u8bd5\u5f53\u524d\u7684\u529f\u80fd\uff0c\u6211\u4eec\u4f1a\u53d1\u73b0<strong>\u590d\u9009\u6846\u7684\u52fe\u9009\u72b6\u6001\u53d1\u751f\u4e86\u7d0a\u4e71<\/strong>\u3002<\/p>\n<p>\u4e0d\u7528\u62c5\u5fc3\uff0c\u8fd9\u4e2a\u95ee\u9898\u662f\u7531 vue <strong>\u9ed8\u8ba4\u7684\u66f4\u65b0\u7b56\u7565<\/strong>\u6240\u5bfc\u81f4\u7684\u3002\u5177\u4f53\u539f\u56e0\u6211\u4eec\u9700\u8981\u5728<strong>\u539f\u7406\u5c42\u9762<\/strong>\u8fdb\u884c\u6df1\u5165\u8bb2\u89e3\u3002<\/p>\n<p>\u90a3\u4e48\u63a5\u4e0b\u6765\uff0c\u6211\u4eec\u9996\u5148\u6765\u770b\u4e00\u4e0b\u5982\u4f55\u89e3\u51b3\u8fd9\u4e2a<strong>\u52fe\u9009\u72b6\u6001\u7d0a\u4e71<\/strong>\u7684\u95ee\u9898\u3002<\/p>\n<h4>3. BugFix\uff1a\u89e3\u51b3\u52fe\u9009\u72b6\u6001\u7d0a\u4e71\u7684\u65b9\u6848<\/h4>\n<p>\u89e3\u51b3\u65b9\u6848\uff0c\u5c31\u662f<strong>\u628a<\/strong>\u6bcf\u4e2a\u590d\u9009\u6846\u7684<strong>\u52fe\u9009\u72b6\u6001<\/strong>\u548c<strong>\u6570\u636e\u6e90<\/strong>\u8fdb\u884c<strong>\u7ed1\u5b9a<\/strong>\uff0c\u8fd9\u6837 vue \u5c31\u80fd\u591f<strong>\u6b63\u786e\u66f4\u65b0<\/strong>\u6bcf\u4e2a\u590d\u9009\u6846\u7684\u52fe\u9009\u72b6\u6001\u4e86\u3002<\/p>\n<p>\u9996\u5148\uff0c\u4fee\u6539 data \u4e0b\u7684\u6570\u636e\u8282\u70b9\uff0c\u4e3a <code>todos<\/code> \u4e0b\u7684\u6bcf\u4e2a\u4efb\u52a1\uff0c\u90fd\u6dfb\u52a0\u4e00\u4e2a <code>done<\/code> \u5c5e\u6027\uff0c\u7528\u6765\u8868\u793a\u5f53\u524d\u4efb\u52a1\u662f\u5426\u5b8c\u6210\uff1a<\/p>\n<pre><code class=\"language-js\">data() {\n  return {\n    \/\/ \u8981\u6dfb\u52a0\u7684\u4efb\u52a1\u540d\u79f0\n    taskName: &#039;&#039;,\n    \/\/ \u4efb\u52a1\u5217\u8868\n    todos: [\n      { task: &#039;\u6668\u7ec3&#039;, done: true },\n      { task: &#039;\u5403\u65e9\u9910&#039;, done: false },\n      { task: &#039;\u5403\u5348\u996d&#039;, done: false }\n    ]\n  }\n}<\/code><\/pre>\n<p>\u5176\u6b21\uff0c\u4fee\u6539 methods \u4e0b\u7684 <code>add<\/code> \u65b9\u6cd5\uff0c\u5728\u6bcf\u6b21\u6dfb\u52a0\u65b0\u4efb\u52a1\u65f6\uff0c\u4e3a\u5176\u9644\u52a0\u4e00\u4e2a <code>done: false<\/code> \u7684\u521d\u59cb\u5b8c\u6210\u72b6\u6001\uff1a<\/p>\n<pre><code class=\"language-js\">methods: {\n  \/\/ \u6dfb\u52a0\u64cd\u4f5c\n  add() {\n    \/\/ 1. \u5982\u679c\u8981\u6dfb\u52a0\u7684\u4efb\u52a1\u540d\u79f0\u4e3a\u7a7a\uff0c\u5219\u63d0\u793a\u8b66\u544a\u4fe1\u606f\n    if (this.taskName.length === 0) return console.warn(&#039;\u4efb\u52a1\u540d\u79f0\u4e0d\u80fd\u4e3a\u7a7a\uff01&#039;)\n    \/\/ 2. \u5411\u5217\u8868\u5934\u90e8\u6dfb\u52a0\u4e00\u4e2a\u65b0\u4efb\u52a1\n    this.todos.unshift({ task: this.taskName })\n    \/\/ 3. \u6e05\u7a7a\u6587\u672c\u6846\u7684\u5185\u5bb9\n    this.taskName = &#039;&#039;\n  }\n}<\/code><\/pre>\n<p>\u6700\u540e\uff0c\u4fee\u6539\u6a21\u677f\u7ed3\u6784\uff0c\u4e3a\u6bcf\u4e2a\u4efb\u52a1\u4e2d\u7684 <code>checkbox<\/code> \u590d\u9009\u6846\u8fdb\u884c <code>v-model<\/code> \u7684\u53cc\u5411\u6570\u636e\u7ed1\u5b9a\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;!-- \u5217\u8868\u533a\u57df --&gt;\n&lt;ul&gt;\n  &lt;li v-for=&quot;item in todos&quot;&gt;\n    &lt;!-- \u4efb\u52a1\u7684\u5b8c\u6210\u72b6\u6001 --&gt;\n    &lt;input type=&quot;checkbox&quot; v-model=&quot;item.done&quot;&gt;\n    &lt;!-- \u4efb\u52a1\u7684\u540d\u79f0 --&gt;\n    &lt;span&gt;{{ item.task }}&lt;\/span&gt;\n  &lt;\/li&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u81f3\u6b64\uff0c\u590d\u9009\u6846\u52fe\u9009\u72b6\u6001\u7d0a\u4e71\u7684\u95ee\u9898\u5f97\u5230\u4e86\u89e3\u51b3\u3002<\/p>\n<p>\u4f46\u662f&#8230;\u5982\u679c\u518d\u4e3a\u6bcf\u4e2a\u4efb\u52a1\u6dfb\u52a0\u4e00\u4e2a\u6587\u672c\u6846\u7684\u5907\u6ce8\u5462\uff1f<strong>\u6587\u672c\u6846\u7684\u72b6\u6001\u4f1a\u7d0a\u4e71\u5417<\/strong>\uff1f<strong>\u53c8\u8be5\u5982\u4f55\u89e3\u51b3\u5462<\/strong>\uff1f<\/p>\n<h4>4. \u65b0\u529f\u80fd\uff1a\u4e3a\u4efb\u52a1\u6dfb\u52a0\u5907\u6ce8<\/h4>\n<p>\u6211\u4eec\u7ee7\u7eed\u4e3a\u6848\u4f8b\u6dfb\u52a0\u65b0\u529f\u80fd\uff0c\u5373\u4e3a\u6bcf\u4e2a\u4efb\u52a1\u6dfb\u52a0\u4e00\u4e2a\u6587\u672c\u6846\u7684\u4f5c\u4e3a\u5907\u6ce8\u4fe1\u606f\u3002<\/p>\n<p>\u4fee\u6539\u6a21\u677f\u7ed3\u6784\u4e2d\u7684\u5217\u8868\u533a\u57df\uff0c\u5728\u6bcf\u4e2a <code>li<\/code> \u5143\u7d20\u4e2d\uff0c\u90fd\u6dfb\u52a0\u4e00\u4e2a\u6587\u672c\u6846\uff0c\u4f5c\u4e3a\u5f53\u524d\u4efb\u52a1\u7684\u5907\u6ce8\u63cf\u8ff0\uff0c\u4ee3\u7801\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;!-- \u5217\u8868\u533a\u57df --&gt;\n&lt;ul&gt;\n  &lt;li v-for=&quot;item in todos&quot;&gt;\n    &lt;!-- \u4efb\u52a1\u7684\u5b8c\u6210\u72b6\u6001 --&gt;\n    &lt;input type=&quot;checkbox&quot; v-model=&quot;item.done&quot;&gt;\n    &lt;!-- \u4efb\u52a1\u7684\u540d\u79f0 --&gt;\n    &lt;span&gt;{{ item.task }}&lt;\/span&gt;\n    &lt;!-- \u6587\u672c\u6846\u5907\u6ce8 --&gt;\n    &lt;input type=&quot;text&quot;&gt;\n  &lt;\/li&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u6539\u9020\u5b8c\u6210\u540e\u7acb\u5373\u6d4b\u8bd5\u5f53\u524d\u7684\u529f\u80fd\uff0c\u6211\u4eec\u4f1a\u53d1\u73b0<strong>\u5728\u6587\u672c\u6846\u4e2d\u586b\u5199\u7684\u5907\u6ce8\u4e5f\u53d1\u751f\u4e86\u7d0a\u4e71<\/strong>\u3002<\/p>\n<p>Don&#8217;t worry\uff0c\u8fd9\u4e2a\u95ee\u9898\u4f9d\u7136\u662f\u7531 vue <strong>\u9ed8\u8ba4\u7684\u66f4\u65b0\u7b56\u7565<\/strong>\u6240\u5bfc\u81f4\u7684\u3002\u5177\u4f53\u539f\u56e0\u7a0d\u540e\u8be6\u7ec6\u4ecb\u7ecd\u3002<\/p>\n<p>\u6211\u4eec\u8fd8\u662f\u5148\u6765\u770b\u4e00\u4e0b\u5982\u4f55\u89e3\u51b3\u8fd9\u4e2a<strong>\u6587\u672c\u6846\u5185\u5bb9\u7d0a\u4e71<\/strong>\u7684\u95ee\u9898\u5427\u3002<\/p>\n<h4>5. BugFix\uff1a\u89e3\u51b3\u6587\u672c\u6846\u5185\u5bb9\u7d0a\u4e71\u7684\u65b9\u6848<\/h4>\n<p>\u672c\u6b21\u7684\u89e3\u51b3\u65b9\u6848\u548c<strong>\u89e3\u51b3\u590d\u9009\u6846\u52fe\u9009\u72b6\u6001\u7d0a\u4e71<\/strong>\u7684\u65b9\u6848\u5982\u51fa\u4e00\u8f99\uff0c\u6838\u5fc3\u601d\u8def\u5c31\u662f<strong>\u628a\u6587\u672c\u6846\u7684\u5185\u5bb9\u548c\u6570\u636e\u6e90\u8fdb\u884c\u53cc\u5411\u7684\u7ed1\u5b9a<\/strong>\u5373\u53ef\u3002<\/p>\n<p>\u9996\u5148\uff0c\u4fee\u6539 data \u4e0b\u7684\u6570\u636e\u8282\u70b9\uff0c\u4e3a <code>todos<\/code> \u4e0b\u7684\u6bcf\u4e2a\u4efb\u52a1\uff0c\u90fd\u6dfb\u52a0\u4e00\u4e2a <code>remark<\/code> \u5c5e\u6027\uff0c\u7528\u6765\u8868\u793a\u5f53\u524d\u4efb\u52a1\u7684\u5907\u6ce8\u63cf\u8ff0\uff1a<\/p>\n<pre><code class=\"language-js\">data() {\n  return {\n    \/\/ \u8981\u6dfb\u52a0\u7684\u4efb\u52a1\u540d\u79f0\n    taskName: &#039;&#039;,\n    \/\/ \u4efb\u52a1\u5217\u8868\n    todos: [\n      { task: &#039;\u6668\u7ec3&#039;, done: true, remark: &#039;\u65e9\u66686\u70b9&#039; },\n      { task: &#039;\u5403\u65e9\u9910&#039;, done: false, remark: &#039;&#039; },\n      { task: &#039;\u5403\u5348\u996d&#039;, done: false, remark: &#039;&#039; }\n    ]\n  }\n}<\/code><\/pre>\n<p>\u5176\u6b21\uff0c\u4fee\u6539 methods \u4e0b\u7684 <code>add<\/code> \u65b9\u6cd5\uff0c\u5728\u6bcf\u6b21\u6dfb\u52a0\u65b0\u4efb\u52a1\u65f6\uff0c\u4e3a\u5176\u9644\u52a0\u4e00\u4e2a <code>remark: &#039;&#039;<\/code> \u7684\u521d\u59cb\u5907\u6ce8\u63cf\u8ff0\uff1a<\/p>\n<pre><code class=\"language-js\">methods: {\n  \/\/ \u6dfb\u52a0\u64cd\u4f5c\n  add() {\n    \/\/ 1. \u5982\u679c\u8981\u6dfb\u52a0\u7684\u4efb\u52a1\u540d\u79f0\u4e3a\u7a7a\uff0c\u5219\u63d0\u793a\u8b66\u544a\u4fe1\u606f\n    if (this.taskName.length === 0) return console.warn(&#039;\u4efb\u52a1\u540d\u79f0\u4e0d\u80fd\u4e3a\u7a7a\uff01&#039;)\n    \/\/ 2. \u5411\u5217\u8868\u5934\u90e8\u6dfb\u52a0\u4e00\u4e2a\u65b0\u4efb\u52a1\n    this.todos.unshift({ task: this.taskName, done: false, remark: &#039;&#039; })\n    \/\/ 3. \u6e05\u7a7a\u6587\u672c\u6846\u7684\u5185\u5bb9\n    this.taskName = &#039;&#039;\n  }\n}<\/code><\/pre>\n<p>\u6700\u540e\uff0c\u4fee\u6539\u6a21\u677f\u7ed3\u6784\uff0c\u4e3a\u6bcf\u4e2a\u4efb\u52a1\u4e2d\u7684\u6587\u672c\u6846\u8fdb\u884c <code>v-model<\/code> \u7684\u53cc\u5411\u6570\u636e\u7ed1\u5b9a\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;!-- \u5217\u8868\u533a\u57df --&gt;\n&lt;ul&gt;\n  &lt;li v-for=&quot;item in todos&quot;&gt;\n    &lt;!-- \u4efb\u52a1\u7684\u5b8c\u6210\u72b6\u6001 --&gt;\n    &lt;input type=&quot;checkbox&quot; v-model=&quot;item.done&quot;&gt;\n    &lt;!-- \u4efb\u52a1\u7684\u540d\u79f0 --&gt;\n    &lt;span&gt;{{ item.task }}&lt;\/span&gt;\n    &lt;!-- \u6587\u672c\u6846\u5907\u6ce8 --&gt;\n    &lt;input type=&quot;text&quot; v-model=&quot;item.remark&quot;&gt;\n  &lt;\/li&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u81f3\u6b64\uff0c\u6587\u672c\u6846\u5185\u5bb9\u7d0a\u4e71\u7684\u95ee\u9898\u4e5f\u5f97\u5230\u4e86\u89e3\u51b3\u3002\u5230\u6b64\u4e3a\u6b62\uff0c\u6211\u4eec\u5df2\u7ecf\u8fde\u7eed\u4e24\u6b21\u89e3\u51b3\u4e86\u72b6\u6001\u7d0a\u4e71\u7684\u95ee\u9898\uff0c\u662f\u65f6\u5019\u505a\u4e00\u4e2a\u5c0f\u5c0f\u7684\u603b\u7ed3\u4e86\uff1a<\/p>\n<ol>\n<li>\u5982\u679c\u5217\u8868\u6bcf\u4e00\u9879\u4e2d\u7684\u8868\u5355\u5143\u7d20\uff0c\u6ca1\u6709\u7ed1\u5b9a\u4efb\u4f55\u6570\u636e\u6e90\uff0c\u5219\u5fc5\u7136\u53d1\u751f\u6570\u636e\u7d0a\u4e71\u7684\u95ee\u9898\n<ul>\n<li>\u8fd9\u79cd<strong>\u6ca1\u6709\u7ed1\u5b9a\u6570\u636e\u6e90<\/strong>\u7684\u60c5\u51b5\uff0c\u6211\u4eec\u79f0\u4e4b\u4e3a\uff1a<strong>\u4e34\u65f6\u72b6\u6001<\/strong><\/li>\n<\/ul>\n<\/li>\n<li>\u5982\u679c\u5217\u8868\u6bcf\u4e00\u9879\u4e2d\u7684\u8868\u5355\u5143\u7d20\uff0c\u548c\u6570\u636e\u6e90\u8fdb\u884c\u4e86\u7ed1\u5b9a\uff0c\u5219\u6570\u636e\u7d0a\u4e71\u7684\u95ee\u9898\u5fc5\u7136\u5f97\u5230\u89e3\u51b3\n<ul>\n<li>\u8fd9\u79cd<strong>\u7ed1\u5b9a\u4e86\u6570\u636e\u6e90<\/strong>\u7684\u60c5\u51b5\uff0c\u6211\u4eec\u79f0\u4e4b\u4e3a\uff1a<strong>\u54cd\u5e94\u5f0f\u72b6\u6001<\/strong><\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<p>\u603b\u4e4b\uff0c\u4e34\u65f6\u72b6\u6001\u6709\u53ef\u80fd\u4f1a\u53d1\u751f\u72b6\u6001\u7d0a\u4e71\u7684\u95ee\u9898\uff0c\u800c\u54cd\u5e94\u5f0f\u72b6\u6001\u4e0d\u4f1a\u53d1\u751f\u72b6\u6001\u7d0a\u4e71\u7684\u95ee\u9898\u3002\u5927\u5bb6\u5148\u8bb0\u4f4f\u8fd9\u79cd<strong>\u8868\u8c61\u5f0f\u7684\u603b\u7ed3<\/strong>\uff0c\u540e\u9762\u4f1a\u6709\u52a9\u4e8e\u5927\u5bb6\u5728\u539f\u7406\u5c42\u9762\u6df1\u5165\u7406\u89e3\u8fd9\u4e2a\u95ee\u9898\u3002<\/p>\n<h4>6. \u57fa\u4e8e key \u503c\u89e3\u51b3\u4e34\u65f6\u72b6\u6001\u7d0a\u4e71\u7684\u95ee\u9898<\/h4>\n<p>\u6211\u4eec\u5728\u4e4b\u524d\u89e3\u51b3\u4e34\u65f6\u72b6\u6001\u7d0a\u4e71\u65f6\uff0c\u6bcf\u6b21\u90fd\u9700\u8981\u4e3a\u8868\u5355\u5143\u7d20\u8fdb\u884c\u6570\u636e\u7684\u7ed1\u5b9a\uff0c\u4ece\u800c\u628a<strong>\u4e34\u65f6\u72b6\u6001<\/strong>\u53d8\u66f4\u4e3a<strong>\u54cd\u5e94\u5f0f\u72b6\u6001<\/strong>\u3002<\/p>\n<p>\u6709\u6ca1\u6709\u5176\u5b83\u65b9\u6848\uff0c\u80fd\u8ba9\u6211\u4eec<strong>\u5728\u4e0d\u6539\u53d8\u4e34\u65f6\u72b6\u6001\u7684\u524d\u63d0\u4e0b<\/strong>\uff0c\u4e5f\u80fd\u89e3\u51b3\u72b6\u6001\u7d0a\u4e71\u7684\u95ee\u9898\u5462\uff1f\u8fd9\u5c31\u9700\u8981\u7528\u5230 v-for \u4e2d\u7684 key \u503c\u4e86\u3002<\/p>\n<p>\u9996\u5148\uff0c\u8ba9\u6211\u4eec\u628a\u9875\u9762\u7ed3\u6784\u91cd\u65b0\u68b3\u7406\u4e00\u904d\uff0c\u628a\u4e34\u65f6\u72b6\u6001\u7d0a\u4e71\u7684\u95ee\u9898\u5b8c\u6574\u7684\u8fd8\u539f\u51fa\u6765\uff0cdata \u4e2d\u7684\u6570\u636e\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-js\">data() {\n  return {\n    \/\/ \u8981\u6dfb\u52a0\u7684\u4efb\u52a1\u540d\u79f0\n    taskName: &#039;&#039;,\n    \/\/ \u4efb\u52a1\u5217\u8868\n    todos: [\n      { task: &#039;\u6668\u7ec3&#039; },\n      { task: &#039;\u5403\u65e9\u9910&#039; },\n      { task: &#039;\u5403\u5348\u996d&#039; }\n    ]\n  }\n}<\/code><\/pre>\n<p>methods \u4e2d\u7684\u65b9\u6cd5\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-js\">methods: {\n  \/\/ \u6dfb\u52a0\u64cd\u4f5c\n  add() {\n    \/\/ 1. \u5982\u679c\u8981\u6dfb\u52a0\u7684\u4efb\u52a1\u540d\u79f0\u4e3a\u7a7a\uff0c\u5219\u63d0\u793a\u8b66\u544a\u4fe1\u606f\n    if (this.taskName.length === 0) return console.warn(&#039;\u4efb\u52a1\u540d\u79f0\u4e0d\u80fd\u4e3a\u7a7a\uff01&#039;)\n    \/\/ 2. \u5411\u5217\u8868\u5934\u90e8\u6dfb\u52a0\u4e00\u4e2a\u65b0\u4efb\u52a1\n    this.todos.unshift({ task: this.taskName })\n    \/\/ 3. \u6e05\u7a7a\u6587\u672c\u6846\u7684\u5185\u5bb9\n    this.taskName = &#039;&#039;\n  }\n}<\/code><\/pre>\n<p>\u6a21\u677f\u7ed3\u6784\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;div id=&quot;app&quot;&gt;\n\n  &lt;!-- \u6dfb\u52a0\u533a\u57df --&gt;\n  &lt;div&gt;\n    &lt;input type=&quot;text&quot; v-model.trim=&quot;taskName&quot;&gt;\n    &lt;button @click=&quot;add&quot;&gt;\u6dfb\u52a0&lt;\/button&gt;\n  &lt;\/div&gt;\n\n  &lt;hr&gt;\n  &lt;!-- \u5217\u8868\u533a\u57df --&gt;\n  &lt;ul&gt;\n    &lt;li v-for=&quot;item in todos&quot;&gt;\n      &lt;!-- \u4efb\u52a1\u7684\u5b8c\u6210\u72b6\u6001 --&gt;\n      &lt;input type=&quot;checkbox&quot;&gt;\n      &lt;!-- \u4efb\u52a1\u7684\u540d\u79f0 --&gt;\n      &lt;span&gt;{{ item.task }}&lt;\/span&gt;\n      &lt;!-- \u6587\u672c\u6846\u5907\u6ce8 --&gt;\n      &lt;input type=&quot;text&quot;&gt;\n    &lt;\/li&gt;\n  &lt;\/ul&gt;\n&lt;\/div&gt;<\/code><\/pre>\n<p>\u95ee\u9898\u8fd8\u539f\u51fa\u6765\u4e4b\u540e\uff0c\u6211\u4eec\u5c31\u8981\u7740\u624b\u4f7f\u7528 key \u503c\u6765\u89e3\u51b3\u4e34\u65f6\u72b6\u6001\u7d0a\u4e71\u7684\u95ee\u9898\u4e86\uff0c4\u4e2a\u6b65\u9aa4\u5982\u4e0b\uff1a<\/p>\n<p><strong>\u6b65\u9aa41<\/strong>\uff1a\u4e3a data \u4e0b\u7684 <code>todos<\/code> \u6570\u636e\uff0c\u6dfb\u52a0\u552f\u4e00\u7684 id \u6807\u8bc6\uff1a<\/p>\n<pre><code class=\"language-js\">data() {\n  return {\n    \/\/ \u8981\u6dfb\u52a0\u7684\u4efb\u52a1\u540d\u79f0\n    taskName: &#039;&#039;,\n    \/\/ \u4efb\u52a1\u5217\u8868\n    todos: [\n      { id: 1, task: &#039;\u6668\u7ec3&#039; },\n      { id: 2, task: &#039;\u5403\u65e9\u9910&#039; },\n      { id: 3, task: &#039;\u5403\u5348\u996d&#039; }\n    ]\n  }\n}<\/code><\/pre>\n<p><strong>\u6b65\u9aa42<\/strong>\uff1a\u4e3a\u4e86\u4fdd\u8bc1\u65b0\u589e\u7684\u4efb\u52a1\u9879\u4e5f\u80fd\u6709<strong>\u9012\u589e\u7684\u552f\u4e00<\/strong>\u7684 id \u503c\uff0c\u6211\u4eec\u9700\u8981\u5728 data \u4e0b\u65b0\u589e\u4e00\u4e2a\u540d\u4e3a <code>nextId<\/code> \u7684\u6570\u636e\uff0c\u5b83\u7684\u503c\u662f\u4e0b\u4e00\u6b21\u6dfb\u52a0\u65f6\u53ef\u7528\u7684 id \u503c\uff1a<\/p>\n<pre><code class=\"language-js\">data() {\n  return {\n    \/\/ \u8981\u6dfb\u52a0\u7684\u4efb\u52a1\u540d\u79f0\n    taskName: &#039;&#039;,\n    \/\/ \u4e0b\u4e00\u6b21\u6dfb\u52a0\u65f6\u53ef\u7528\u7684 id \u503c\n    nextId: 4,\n    \/\/ \u4efb\u52a1\u5217\u8868\n    todos: [\n      { id: 1, task: &#039;\u6668\u7ec3&#039; },\n      { id: 2, task: &#039;\u5403\u65e9\u9910&#039; },\n      { id: 3, task: &#039;\u5403\u5348\u996d&#039; }\n    ]\n  }\n},<\/code><\/pre>\n<p><strong>\u6b65\u9aa43<\/strong>\uff1a\u4fee\u6539 methods\u4e0b\u7684 <code>add<\/code> \u65b9\u6cd5\uff0c\u4e3a\u6bcf\u6b21\u65b0\u589e\u7684\u4efb\u52a1\u9644\u5e26\u552f\u4e00\u7684 id \u6807\u8bc6\uff0c\u6dfb\u52a0\u5b8c\u6210\u540e\u8bb0\u5f97\u66f4\u65b0 <code>nextId<\/code> \u7684\u503c\uff1a<\/p>\n<pre><code class=\"language-js\">methods: {\n  \/\/ \u6dfb\u52a0\u64cd\u4f5c\n  add() {\n    \/\/ 1. \u5982\u679c\u8981\u6dfb\u52a0\u7684\u4efb\u52a1\u540d\u79f0\u4e3a\u7a7a\uff0c\u5219\u63d0\u793a\u8b66\u544a\u4fe1\u606f\n    if (this.taskName.length === 0) return console.warn(&#039;\u4efb\u52a1\u540d\u79f0\u4e0d\u80fd\u4e3a\u7a7a\uff01&#039;)\n    \/\/ 2. \u5411\u5217\u8868\u5934\u90e8\u6dfb\u52a0\u4e00\u4e2a\u65b0\u4efb\u52a1\n    this.todos.unshift({ id: this.nextId, task: this.taskName })\n    \/\/ 3. \u6e05\u7a7a\u6587\u672c\u6846\u7684\u5185\u5bb9\n    this.taskName = &#039;&#039;\n    \/\/ 4. \u66f4\u65b0 nextId \u7684\u503c\n    this.nextId++\n  }\n}<\/code><\/pre>\n<p><strong>\u6b65\u9aa44<\/strong>\uff1a\u4fee\u6539\u6a21\u677f\u7ed3\u6784\u4e2d\u7684 <code>v-for<\/code> \u5faa\u73af\uff0c\u5728 <code>v-for <\/code> \u5faa\u73af\u7684\u540c\u65f6\uff0c\u4e3a\u5f53\u524d\u5faa\u73af\u7684\u5143\u7d20\u52a8\u6001\u7ed1\u5b9a <code>key<\/code> \u5c5e\u6027\u7684\u503c\uff0c\u503c\u4e3a\u5f53\u524d\u5faa\u73af\u9879\u7684 id\uff0c\u5373 <code>item.id<\/code>\u3002\u4ee3\u7801\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;!-- \u5217\u8868\u533a\u57df --&gt;\n&lt;ul&gt;\n  &lt;li v-for=&quot;item in todos&quot; :key=&quot;item.id&quot;&gt;\n    &lt;!-- \u4efb\u52a1\u7684\u5b8c\u6210\u72b6\u6001 --&gt;\n    &lt;input type=&quot;checkbox&quot;&gt;\n    &lt;!-- \u4efb\u52a1\u7684\u540d\u79f0 --&gt;\n    &lt;span&gt;{{ item.task }}&lt;\/span&gt;\n    &lt;!-- \u6587\u672c\u6846\u5907\u6ce8 --&gt;\n    &lt;input type=&quot;text&quot;&gt;\n  &lt;\/li&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u5230\u6b64\u4e3a\u6b62\uff0c\u6211\u4eec\u6210\u529f\u5229\u7528 <code>v-for<\/code> \u914d\u5957\u7684 key \u503c\uff0c\u89e3\u51b3\u4e86\u4e34\u65f6\u72b6\u6001\u7d0a\u4e71\u7684\u95ee\u9898\u3002\u597d\u5904\u67092\u4e2a\uff1a<\/p>\n<ol>\n<li><strong>\u65e0\u9700\u628a\u4e34\u65f6\u72b6\u6001\u8f6c\u53d8\u4e3a\u54cd\u5e94\u5f0f\u72b6\u6001<\/strong><\/li>\n<li>\u53ea\u9700\u5728\u5faa\u73af\u671f\u95f4<strong>\u7ed1\u5b9a\u4e00\u6b21 key \u503c<\/strong>\u5373\u53ef\u89e3\u51b3\u95ee\u9898\uff0c\u65e0\u9700\u50cf\u4e4b\u524d\u90a3\u6837\u4e3a\u6bcf\u4e2a\u8868\u5355\u5143\u7d20<strong>\u4f9d\u6b21\u5b9a\u4e49\u6570\u636e\u6e90<\/strong>\u3001\u518d<strong>\u4f9d\u6b21\u8fdb\u884c v-model \u7684\u7ed1\u5b9a<\/strong><\/li>\n<\/ol>\n<h4>7. key \u503c\u7684\u4f7f\u7528\u6ce8\u610f\u4e8b\u9879<\/h4>\n<ol>\n<li>key \u503c\u5fc5\u987b\u5177\u6709\u552f\u4e00\u6027\uff0c\u4e0d\u80fd\u91cd\u590d<\/li>\n<li>key \u503c\u5fc5\u987b\u662f number \u6216 string \u6216 symbol \u7c7b\u578b<\/li>\n<li>\u5c3d\u91cf\u4e0d\u8981\u4f7f\u7528\u7d22\u5f15\u5f53\u505a key \u503c\uff0c\u56e0\u4e3a\u7d22\u5f15\u4e0d\u5177\u6709\u552f\u4e00\u6027<\/li>\n<li>\u4e3a\u4e86\u907f\u514d\u51fa\u73b0\u975e\u9884\u671f\u7684 DOM \u66f4\u65b0\u95ee\u9898\uff0c\u63a8\u8350\u7ed9 v-for \u5faa\u73af\u7684\u5143\u7d20\u7ed1\u5b9a\u552f\u4e00\u7684 key \u503c<\/li>\n<\/ol>\n<blockquote>\n<p>\u7b80\u5355\u7c97\u66b4\u7684\u8bb0\u5fc6\u65b9\u6cd5\uff1a\u53ea\u8981\u4f7f\u7528\u4e86 v-for \u6307\u4ee4\uff0c\u5c31\u4e00\u5b9a\u8981\u52a0 key \u503c\u7ed1\u5b9a\uff1b\u800c\u4e14\u5c3d\u91cf\u7528 id \u5f53\u505a key \u503c\uff0c\u6ca1\u6709 id \u7684\u60c5\u51b5\u4e0b\u627e\u5177\u6709\u552f\u4e00\u6027\u7684 number\u3001string \u503c\u5f53\u505a key\u3002<\/p>\n<\/blockquote>\n<h3>3.8 v-for \u4e2d key \u503c\u7684\u539f\u7406<\/h3>\n<h4>1. \u865a\u62df DOM \u7684\u6982\u5ff5<\/h4>\n<p><strong>\u865a\u62df DOM<\/strong> \u53c8\u53eb\u505a <strong>VNode<\/strong>\uff0c\u672c\u8d28\u4e0a<strong>\u662f\u7528\u6765\u63cf\u8ff0 DOM \u7ed3\u6784\u7684 JavaScript \u5bf9\u8c61<\/strong>\u3002\u5b83\u5728 Vue \u4e2d\u7528\u6765\u63cf\u8ff0\u4e0d\u540c\u7c7b\u578b\u7684\u8282\u70b9\uff0c\u4f8b\u5982\u666e\u901a\u5143\u7d20\u8282\u70b9\u3001\u7ec4\u4ef6\u8282\u70b9\u7b49\u3002<\/p>\n<p>\u4f8b\u5982\uff0c\u6211\u4eec\u63d0\u4f9b\u5982\u4e0b\u7684 DOM \u7ed3\u6784\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;h1 id=&quot;topicTitle&quot; title=&quot;\u6807\u9898&quot;&gt;This is an article title.&lt;\/h1&gt;<\/code><\/pre>\n<p>\u5c06\u5176\u8f6c\u5316\u4e3a VNode \u4e4b\u540e\uff0c\u683c\u5f0f\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-js\">const vnode = {\n  type: &#039;h1&#039;,\n  props: {\n    id: &#039;topicTitle&#039;,\n    title: &#039;\u6807\u9898&#039;\n  },\n  \/\/ \u5b50\u8282\u70b9\u662f\u666e\u901a\u6587\u672c\n  children: &#039;This is an article title.&#039;\n}<\/code><\/pre>\n<p>\u5176\u4e2d\uff1a<\/p>\n<ol>\n<li>type \u5c5e\u6027\u8868\u793a DOM \u7684\u6807\u7b7e\u7c7b\u578b<\/li>\n<li>props \u5c5e\u6027\u8868\u793a DOM \u4e0a\u7684\u4e00\u4e9b\u9644\u52a0\u4fe1\u606f\uff0c\u4f8b\u5982 id\u3001title \u7b49<\/li>\n<li>children \u5c5e\u6027\u8868\u793a DOM \u7684\u5b50\u8282\u70b9\uff0c\u53ef\u4ee5\u662f\u6587\u672c\uff0c\u4e5f\u53ef\u4ee5\u662f\u4e00\u4e2a VNode \u6570\u7ec4<\/li>\n<\/ol>\n<p>\u518d\u4f8b\u5982\uff0c\u6211\u4eec\u63d0\u4f9b\u5982\u4e0b\u7684 DOM \u7ed3\u6784\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;ul&gt;\n  &lt;li&gt;\u7b2c1\u4e2a\u5b50\u5143\u7d20&lt;\/li&gt;\n  &lt;li&gt;\u7b2c2\u4e2a\u5b50\u5143\u7d20&lt;\/li&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u5c06\u5176\u8f6c\u5316\u4e3a VNode \u4e4b\u540e\uff0c\u683c\u5f0f\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-js\">const vnode = {\n  type: &#039;ul&#039;,\n  props: {},\n  \/\/ \u5b50\u8282\u70b9\u662f VNode \u6570\u7ec4\n  children: [{\n      type: &#039;li&#039;,\n      props: {},\n      children: &#039;\u7b2c1\u4e2a\u5b50\u5143\u7d20&#039;\n    }, {\n      type: &#039;li&#039;,\n      props: {},\n      children: &#039;\u7b2c2\u4e2a\u5b50\u5143\u7d20&#039;\n    }\n  ]\n}<\/code><\/pre>\n<h4>2. \u865a\u62df DOM \u7684\u4f18\u52bf<\/h4>\n<p>\u6700\u5927\u7684\u4f18\u52bf\uff1a<strong>\u8de8\u5e73\u53f0\u6e32\u67d3<\/strong>\uff0c\u4e0d\u540c\u7684\u5e73\u53f0\u53ef\u4ee5\u57fa\u4e8e\u81ea\u5df1\u7684\u5b9e\u73b0\uff0c\u8f7b\u677e\u7684\u628a VNode \u8f6c\u5316\u4e3a\u5404\u81ea\u5e73\u53f0\u7684\u4ee3\u7801<\/p>\n<ul>\n<li>\u628a VNode \u6e32\u67d3\u4e3a\u5c0f\u7a0b\u5e8f\u5e73\u53f0\u7684\u7ec4\u4ef6<\/li>\n<li>\u628a VNode \u6e32\u67d3\u4e3a Weex \u79fb\u52a8\u7aef\u7684\u7ec4\u4ef6<\/li>\n<\/ul>\n<p><strong>\u865a\u62df DOM<\/strong> \u914d\u5408 <strong>Diff \u7b97\u6cd5<\/strong>\uff0c\u80fd\u591f\u5c3d\u53ef\u80fd\u51cf\u5c11 Vue \u6846\u67b6\u5bf9 DOM \u7684\u64cd\u4f5c<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230621155055556.png\" alt=\"image-20230621155055556\" style=\"zoom:67%;\" \/><\/p>\n<p>\u5982\u4e0a\u56fe\u6240\u793a\uff0c\u5982\u679c\u4f7f\u7528\u539f\u751f\u64cd\u4f5c\u66f4\u65b0\u9875\u9762\u7ed3\u6784\u65f6\uff0c\u4f1a\u79fb\u9664\u6240\u6709\u65e7 DOM \u8282\u70b9\uff0c\u5e76\u91cd\u65b0\u521b\u5efa\u65b0 DOM \u8282\u70b9\u3002<\/p>\n<p>\u800c\u6211\u4eec\u53ef\u4ee5\u660e\u663e\u7684\u89c2\u5bdf\u5230\uff0c\u76f8\u6bd4\u4e8e\u65e7 DOM\uff0c\u65b0 DOM \u5143\u7d20<strong>\u53ea\u662f\u987a\u5e8f\u4e0a\u53d1\u751f\u4e86\u53d8\u5316<\/strong>\uff1a\u65b0 DOM \u628a P3 \u79fb\u52a8\u5230\u4e86 P1 \u4e4b\u524d\u3002\u6211\u4eec\u53ea\u9700\u8981\u66f4\u65b0 DOM \u5143\u7d20\u7684\u5148\u540e\u987a\u5e8f\u5373\u53ef\uff0c\u6839\u672c\u4e0d\u7528\u91cd\u65b0\u521b\u5efa\u6240\u6709\u7684\u5143\u7d20\u3002<\/p>\n<p><strong>\u865a\u62df DOM \u914d\u5408 Diff \u7b97\u6cd5\uff0c\u53ef\u4ee5\u5b9e\u73b0\u65e7 DOM \u5143\u7d20\u7684\u590d\u7528\uff0c\u4ece\u800c\u51cf\u5c11\u4e86\u4e0d\u5fc5\u8981\u7684 DOM \u9500\u6bc1\u548c\u521b\u5efa<\/strong>\u7684\u8fc7\u7a0b\u3002<\/p>\n<p><strong>\u8bef\u533a<\/strong>\uff1a\u865a\u62df DOM \u7684\u6027\u80fd\u4e00\u5b9a\u6bd4\u624b\u52a8\u64cd\u4f5c\u539f\u751f DOM \u597d\u3002\u8bf7\u6ce8\u610f\uff0c\u8fd9\u4e2a\u8bf4\u6cd5\u662f<strong>\u9519\u8bef\u7684<\/strong>\u3002<\/p>\n<ol>\n<li>\u4ece <strong>DOM \u590d\u7528\u6027<\/strong>\u7684\u89d2\u5ea6\u51fa\u53d1\u6765\u5bf9\u6bd4\u4e24\u8005\uff0c\u865a\u62df DOM \u7684\u6027\u80fd\u6bd4\u624b\u52a8\u64cd\u4f5c\u539f\u751f DOM \u8981\u597d\uff0c\u8fd9\u662f\u6bcb\u5eb8\u7f6e\u7591\u7684\u3002<\/li>\n<li>\u4ece <strong>DOM \u7684\u521b\u5efa\u6548\u7387<\/strong>\u65b9\u9762\u51fa\u53d1\u6765\u5bf9\u6bd4\u4e24\u8005\uff0c\u624b\u52a8\u64cd\u4f5c\u539f\u751f DOM \u7684\u6027\u80fd\u66f4\u597d\u3002<\/li>\n<\/ol>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230621161008916.png\" alt=\"image-20230621161008916\" style=\"zoom:60%;\" \/><\/p>\n<h4>3. \u5c31\u5730\u66f4\u65b0\u7b56\u7565<\/h4>\n<p>\u5047\u8bbe data \u4e2d\u5b58\u5728\u5982\u4e0b\u7684\u4e00\u7ec4 <code>todos<\/code> \u6570\u636e\uff0c\u6211\u4eec\u5e0c\u671b\u628a\u5b83\u6e32\u67d3\u4e3a\u9875\u9762\u4e0a\u7684 ul \u65e0\u5e8f\u5217\u8868\uff1a<\/p>\n<pre><code class=\"language-js\">data() {\n  return {\n    \/\/ \u4efb\u52a1\u5217\u8868\n    todos: [\n      { task: &#039;\u6668\u7ec3&#039; },\n      { task: &#039;\u5403\u65e9\u9910&#039; },\n      { task: &#039;\u5403\u5348\u996d&#039; }\n    ]\n  }\n}<\/code><\/pre>\n<p>\u6267\u884c\u7684 v-for \u6307\u4ee4\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;ul&gt;\n  &lt;li v-for=&quot;item in todos&quot;&gt;{{ item.task }}&lt;\/li&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u751f\u6210\u7684\u865a\u62df DOM \uff08VNode\uff09\u5982\u4e0b\u6240\u793a\uff1a<\/p>\n<pre><code class=\"language-js\">const vnode = {\n  type: &#039;ul&#039;,\n  props: {},\n  \/\/ VNode \u6570\u7ec4\uff0c\u901a\u8fc7 v-for \u6307\u4ee4\u6e32\u67d3\u7684\u5b50\u8282\u70b9\n  children: [{\n    type: &#039;li&#039;,\n    props: { key: null },\n    children: &#039;\u6668\u7ec3&#039;\n  }, {\n    type: &#039;li&#039;,\n    props: { key: null },\n    children: &#039;\u5403\u65e9\u9910&#039;\n  }, {\n    type: &#039;li&#039;,\n    props: { key: null },\n    children: &#039;\u5403\u5348\u996d&#039;\n  }]\n}<\/code><\/pre>\n<p>\u7531\u4e8e\u8fd9\u662f\u7b2c\u4e00\u6b21\u6e32\u67d3\u9875\u9762\uff0c\u6240\u4ee5\u4f1a\u76f4\u63a5\u57fa\u4e8e\u865a\u62df DOM \u521b\u5efa\u771f\u5b9e\u7684 DOM \u7ed3\u6784\uff0c\u5e76\u628a\u4e0a\u4e00\u6b65\u751f\u6210\u7684 VNode <strong>\u6807\u8bb0<\/strong>\u4e3a<strong>\u65e7\u865a\u62df DOM<\/strong>\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;ul&gt;\n  &lt;li&gt;\u6668\u7ec3&lt;\/li&gt;\n  &lt;li&gt;\u5403\u65e9\u9910&lt;\/li&gt;\n  &lt;li&gt;\u5403\u5348\u996d&lt;\/li&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u81f3\u6b64\uff0c\u9875\u9762\u7684<strong>\u9996\u6b21\u6e32\u67d3\u5b8c\u6210<\/strong>\u3002<\/p>\n<p>\u63a5\u4e0b\u6765\uff0c\u5982\u679c\u5728 <code>todos<\/code> \u6570\u636e\u7684\u5934\u90e8\u63d2\u5165\u4e00\u4e2a\u65b0\u4efb\u52a1\uff0c\u5219\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">data() {\n  return {\n    \/\/ \u4efb\u52a1\u5217\u8868\n    todos: [\n      { task: &#039;\u6d4b\u8bd5&#039; },\n      { task: &#039;\u6668\u7ec3&#039; },\n      { task: &#039;\u5403\u65e9\u9910&#039; },\n      { task: &#039;\u5403\u5348\u996d&#039; }\n    ]\n  }\n}<\/code><\/pre>\n<p>\u751f\u6210\u7684<strong>\u65b0\u865a\u62df DOM<\/strong> \uff08VNode\uff09\u5982\u4e0b\u6240\u793a\uff1a<\/p>\n<pre><code class=\"language-js\">const vnode = {\n  type: &#039;ul&#039;,\n  props: {},\n  \/\/ VNode \u6570\u7ec4\uff0c\u901a\u8fc7 v-for \u6307\u4ee4\u6e32\u67d3\u7684\u5b50\u8282\u70b9\n  children: [{\n    type: &#039;li&#039;,\n    props: { key: null },\n    children: &#039;\u6d4b\u8bd5&#039;\n  }, {\n    type: &#039;li&#039;,\n    props: { key: null },\n    children: &#039;\u6668\u7ec3&#039;\n  }, {\n    type: &#039;li&#039;,\n    props: { key: null },\n    children: &#039;\u5403\u65e9\u9910&#039;\n  }, {\n    type: &#039;li&#039;,\n    props: { key: null },\n    children: &#039;\u5403\u5348\u996d&#039;\n  }]\n}<\/code><\/pre>\n<p>\u6ce8\u610f\uff1a\u4e3a\u4e86\u63d0\u9ad8 DOM \u64cd\u4f5c\u7684\u6027\u80fd\uff0cVue \u4f1a\u5c3d\u53ef\u80fd\u7684\u590d\u7528\u5df2\u5b58\u5728\u7684\u65e7 DOM \u5143\u7d20\uff0c\u4ece\u800c\u51cf\u5c11\u65b0 DOM \u7684\u521b\u5efa\u3002\u6b64\u65f6\uff0cVue \u4f1a\u5bf9\u65b0\u65e7 VNode \u8fdb\u884c\u5bf9\u6bd4\u3002<\/p>\n<p>\u90a3\u4e48<strong>\u5bf9\u6bd4\u7684\u7b56\u7565<\/strong>\u662f\u4ec0\u4e48\u5462\uff1f\u7531\u4e8e\u6211\u4eec\u6ca1\u6709\u7ed9 v-for \u6307\u4ee4\u7ed1\u5b9a key \u503c\uff0c\u6240\u4ee5\u5f53\u524d\u6bcf\u4e2a li \u5bf9\u5e94\u7684 VNode \u7684 key \u9ed8\u8ba4\u7b49\u4e8e null\u3002<strong>\u5f53 key \u503c\u4e3a null \u7684\u65f6\u5019<\/strong>\uff0cVue \u7684\u5bf9\u6bd4\u7b56\u7565\u662f\uff1a<strong>\u5c31\u5730\u66f4\u65b0<\/strong>\u3002<\/p>\n<p>\u5177\u4f53\u6765\u8bb2\uff0c\u5c31\u5730\u66f4\u65b0\u7b56\u7565\u6307\u7684\u662f<strong>\u9010\u5c42\u5bf9\u6bd4\u65b0\u65e7 VNode \u8282\u70b9<\/strong>\uff1a<\/p>\n<ol>\n<li>\u5982\u679c\u65b0\u65e7 VNode \u7c7b\u578b\u76f8\u540c\uff0c\u5219\u8fdb\u884c\u66f4\u65b0<\/li>\n<li>\u5982\u679c\u65b0\u65e7 VNode \u7c7b\u578b\u4e0d\u540c\uff0c\u5219\u79fb\u9664\u65e7\u5143\u7d20\uff0c\u521b\u5efa\u65b0\u5143\u7d20<\/li>\n<li>\u5982\u679c\u65e7 VNode \u6bd4\u65b0 VNode \u591a\uff0c\u5219\u79fb\u9664\u591a\u4f59\u7684\u65e7\u5143\u7d20<\/li>\n<li>\u5982\u679c\u65b0 VNode \u6bd4\u65e7 VNode \u591a\uff0c\u5219\u521b\u5efa\u591a\u4f59\u7684\u65b0\u5143\u7d20<\/li>\n<\/ol>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230621174540396.png\" alt=\"image-20230621174540396\" style=\"zoom:80%;\" \/><\/p>\n<p>\u57fa\u4e8e\u5c31\u5730\u66f4\u65b0\u7b56\u7565\uff0c\u4e0a\u8ff0\u7684\u65b0\u65e7 VNode \u5bf9\u6bd4\u5b8c\u6210\u4e4b\u540e\uff0cVue \u5f97\u5230\u7684\u66f4\u65b0\u8fc7\u7a0b\u4e3a\uff1a<\/p>\n<ol>\n<li><strong>\u590d\u7528<\/strong>3\u4e2a li \u7684\u65e7 DOM\uff0c\u5e76<strong>\u66f4\u65b0<\/strong>\u8fd9\u4e09\u4e2a\u65e7 DOM \u7684\u6587\u672c\u5b50\u8282\u70b9<\/li>\n<li><strong>\u521b\u5efa<\/strong>1\u4e2a\u65b0\u7684 li DOM\uff0c\u5e76\u628a\u5b83<strong>\u6dfb\u52a0<\/strong>\u5230 ul \u4e2d<\/li>\n<\/ol>\n<h4>4. \u5c31\u5730\u66f4\u65b0\u7b56\u7565\u548c\u4e34\u65f6\u72b6\u6001<\/h4>\n<p>\u638c\u63e1\u4e86 Vue \u7684\u5c31\u5730\u66f4\u65b0\u7b56\u7565\u4e4b\u540e\uff0c\u6211\u4eec\u518d\u7528\u5b83\u5206\u6790\u4e00\u4e0b <strong>3.7.2<\/strong> \u4e2d\u7684<strong>\u590d\u9009\u6846\u52fe\u9009\u72b6\u6001\u7d0a\u4e71<\/strong>\u7684 Bug\u3002<\/p>\n<p>v-for \u7684\u6307\u4ee4\u4e3a\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;ul&gt;\n  &lt;li v-for=&quot;item in todos&quot;&gt;\n    &lt;!-- \u4efb\u52a1\u7684\u5b8c\u6210\u72b6\u6001 --&gt;\n    &lt;input type=&quot;checkbox&quot;&gt;\n    &lt;!-- \u4efb\u52a1\u7684\u540d\u79f0 --&gt;\n    &lt;span&gt;{{ item.task }}&lt;\/span&gt;\n  &lt;\/li&gt;\n&lt;\/ul&gt;<\/code><\/pre>\n<p>\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">data() {\n  return {\n    \/\/ \u4efb\u52a1\u5217\u8868\n    todos: [\n      { task: &#039;\u6668\u7ec3&#039; },\n      { task: &#039;\u5403\u65e9\u9910&#039; }\n    ]\n  }\n}<\/code><\/pre>\n<p>\u9996\u6b21\u6e32\u67d3\u5f97\u5230\u7684 VNode \u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">const vnode = {\n  type: &#039;ul&#039;,\n  props: {},\n  \/\/ VNode \u6570\u7ec4\uff0c\u901a\u8fc7 v-for \u6307\u4ee4\u6e32\u67d3\u7684\u5b50\u8282\u70b9\n  children: [{ \/\/ \u7b2c1\u4e2ali\uff08VNode\uff09\n    type: &#039;li&#039;,\n    props: { key: null },\n    children: [{\n      type: &#039;input&#039;,\n      props: { type: &#039;checkbox&#039; }\n    }, {\n      type: &#039;span&#039;,\n      props: {},\n      children: &#039;\u6668\u7ec3&#039;\n    }]\n  }, { \/\/ \u7b2c2\u4e2ali\uff08VNode\uff09\n    type: &#039;li&#039;,\n    props: { key: null },\n    children: [{\n      type: &#039;input&#039;,\n      props: { type: &#039;checkbox&#039; }\n    }, {\n      type: &#039;span&#039;,\n      props: {},\n      children: &#039;\u5403\u65e9\u9910&#039;\n    }]\n  }]\n}<\/code><\/pre>\n<p>\u81f3\u6b64\uff0c\u9875\u9762\u7684<strong>\u9996\u6b21\u6e32\u67d3\u5b8c\u6210<\/strong>\u3002<\/p>\n<p>\u63a5\u4e0b\u6765\uff0c\u5982\u679c\u5728 <code>todos<\/code> \u6570\u636e\u7684\u5934\u90e8\u63d2\u5165\u4e00\u4e2a\u65b0\u4efb\u52a1\uff0c\u5219\u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a<\/p>\n<pre><code class=\"language-js\">data() {\n  return {\n    \/\/ \u4efb\u52a1\u5217\u8868\n    todos: [\n      { task: &#039;\u6d4b\u8bd5&#039; },\n      { task: &#039;\u6668\u7ec3&#039; },\n      { task: &#039;\u5403\u65e9\u9910&#039; }\n    ]\n  }\n}<\/code><\/pre>\n<p>\u751f\u6210\u7684<strong>\u65b0\u865a\u62df DOM<\/strong> \uff08VNode\uff09\u5982\u4e0b\u6240\u793a\uff1a<\/p>\n<pre><code class=\"language-js\">const vnode = {\n  type: &#039;ul&#039;,\n  props: {},\n  \/\/ VNode \u6570\u7ec4\uff0c\u901a\u8fc7 v-for \u6307\u4ee4\u6e32\u67d3\u7684\u5b50\u8282\u70b9\n  children: [{ \/\/ \u7b2c1\u4e2ali\uff08VNode\uff09\n    type: &#039;li&#039;,\n    props: { key: null },\n    children: [{ \n      type: &#039;input&#039;,\n      props: { type: &#039;checkbox&#039; }\n    }, {\n      type: &#039;span&#039;,\n      props: {},\n      children: &#039;\u6d4b\u8bd5&#039;\n    }]\n  }, { \/\/ \u7b2c2\u4e2ali\uff08VNode\uff09\n    type: &#039;li&#039;,\n    props: { key: null },\n    children: [{\n      type: &#039;input&#039;,\n      props: { type: &#039;checkbox&#039; }\n    }, {\n      type: &#039;span&#039;,\n      props: {},\n      children: &#039;\u6668\u7ec3&#039;\n    }]\n  }, { \/\/ \u7b2c3\u4e2ali\uff08VNode\uff09\n    type: &#039;li&#039;,\n    props: { key: null },\n    children: [{\n      type: &#039;input&#039;,\n      props: { type: &#039;checkbox&#039; }\n    }, {\n      type: &#039;span&#039;,\n      props: {},\n      children: &#039;\u5403\u65e9\u9910&#039;\n    }]\n  }]\n}<\/code><\/pre>\n<p>\u4f9d\u636e<strong>\u5c31\u5730\u66f4\u65b0\u7b56\u7565<\/strong>\uff0c\u65b0\u65e7 VNode \u5177\u4f53\u7684\u5bf9\u6bd4\u8fc7\u7a0b\u5982\u4e0b\u56fe\u6240\u793a\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230621200601419.png\" alt=\"image-20230621200601419\" style=\"zoom:80%;\" \/><\/p>\n<p>\u7ecf\u8fc7\u5206\u6790\u53d1\u73b0\uff0c\u6bcf\u4e2a <code>checkbox<\/code> \u590d\u9009\u6846\u7684\u52fe\u9009\u72b6\u6001\uff0c\u4e0d\u5f71\u54cd<strong>\u5c31\u5730\u66f4\u65b0<\/strong>\u7684\u5bf9\u6bd4\u8fc7\u7a0b\u3002\u590d\u9009\u6846\u53ea\u662f\u7b80\u5355\u7c97\u66b4\u7684\u88ab\u5c31\u5730\u590d\u7528\u4e86\u3002\u56e0\u6b64\u51fa\u73b0\u4e86<strong>\u4e34\u65f6\u72b6\u6001\u7d0a\u4e71<\/strong>\u7684\u95ee\u9898\u3002<\/p>\n<h4>5. \u5c31\u5730\u66f4\u65b0\u7b56\u7565\u548c\u6570\u636e\u7ed1\u5b9a<\/h4>\n<p>\u5728 <strong>3.7.3<\/strong> \u4e2d\uff0c\u6211\u4eec\u7ed9\u590d\u9009\u6846\u6dfb\u52a0\u4e86 <code>v-model<\/code> \u7684\u53cc\u5411\u6570\u636e\u7ed1\u5b9a\uff0c\u89e3\u51b3\u4e86<strong>\u590d\u9009\u6846\u52fe\u9009\u72b6\u6001\u7d0a\u4e71<\/strong>\u7684\u95ee\u9898\u3002<\/p>\n<p>\u8fd9\u5176\u5b9e\u5f88\u597d\u7406\u89e3\uff0c\u56e0\u4e3a Vue \u5728\u8fdb\u884c\u65b0\u65e7 VNode \u5bf9\u6bd4\u7684\u8fc7\u7a0b\u4e2d\uff0c\u4f1a\u6839\u636e<strong>\u6570\u636e\u9a71\u52a8\u89c6\u56fe<\/strong>\u7684\u601d\u60f3\uff0c\u8ba9<strong>\u771f\u5b9e DOM \u6240\u663e\u793a\u7684\u6570\u636e<\/strong>\u548c <strong>data \u4e2d\u7684\u6570\u636e<\/strong>\u4fdd\u6301\u4e00\u81f4\u3002<\/p>\n<p>\u4f46\u662f\uff0c<strong>\u4e34\u65f6\u72b6\u6001<\/strong>\u4e0d\u53d7<strong>\u6570\u636e\u9a71\u52a8\u89c6\u56fe<\/strong>\u7684\u5f71\u54cd\uff0c\u56e0\u4e3a\u5b83<strong>\u6ca1\u6709<\/strong>\u4e0e\u4efb\u4f55\u54cd\u5e94\u5f0f\u6570\u636e\u8fdb\u884c\u7ed1\u5b9a\u3002<\/p>\n<h4>6. key \u503c\u66f4\u65b0\u7b56\u7565<\/h4>\n<p>\u4e0d\u540c\u4e8e\u9ed8\u8ba4\u7684<strong>\u5c31\u5730\u66f4\u65b0<\/strong>\u7b56\u7565\uff0ckey \u503c\u66f4\u65b0\u7b56\u7565\u53ef\u4ee5\u6700\u5927\u9650\u5ea6\u7684\u5b9e\u73b0\u5df2\u6709\u5143\u7d20\u7684<strong>\u91cd\u6392<\/strong>\u548c<strong>\u91cd\u7528<\/strong>\u3002<\/p>\n<p>\u5728 key \u503c\u66f4\u65b0\u7b56\u7565\u4e2d\uff0cVue \u8ba4\u4e3a\uff1a<\/p>\n<ol>\n<li>\u5177\u6709\u76f8\u540c key \u503c\u7684\u65b0\u65e7 VNode \u662f\u53ef\u590d\u7528\u7684\u5143\u7d20<\/li>\n<li>\u5982\u679c\u65b0 VNode \u5bf9\u5e94\u7684 key \u503c\u4e0d\u5b58\u5728\u4e8e\u65e7 VNode \u4e2d\uff0c\u5219\u5f53\u524d\u7684\u65b0 VNode \u9700\u8981\u521b\u5efa\u5e76\u6dfb\u52a0<\/li>\n<li>\u5982\u679c\u65e7 VNode \u5bf9\u5e94\u7684 key \u503c\u4e0d\u5b58\u5728\u4e8e\u65e7 VNode \u4e2d\uff0c\u5219\u5f53\u524d\u7684\u65e7 VNode \u9700\u8981\u88ab\u5220\u9664\uff08\u5378\u8f7d\uff09<\/li>\n<\/ol>\n<p>\u5728 <strong>3.7.6<\/strong> \u4e2d\uff0c\u6211\u4eec\u7ed9 <code>v-for<\/code> \u5faa\u73af\u751f\u6210\u7684 <code>&lt;li&gt;<\/code> \u6dfb\u52a0\u4e86 <code>:key=&quot;item.id&quot;<\/code> \u7684 key \u503c\u7ed1\u5b9a\uff0c\u4ece\u800c\u89e3\u51b3\u4e86<strong>\u4e34\u65f6\u72b6\u6001\u7d0a\u4e71<\/strong>\u7684\u95ee\u9898\u3002<\/p>\n<p>\u5728\u5217\u8868\u5934\u90e8\u65b0\u589e\u4e00\u4e2a\u5143\u7d20\uff0c\u5219 key \u503c\u66f4\u65b0\u7b56\u7565\u7684\u6267\u884c\u8fc7\u7a0b\u5982\u4e0b\uff1a<\/p>\n<ol>\n<li>\n<p>\u521d\u59cb Diff \u72b6\u6001\uff0c\u5b9a\u4e49\u4e09\u4e2a\u53d8\u91cf\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627134255530.png\" alt=\"image-20230627134255530\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p>\u7b2c1\u6b21Diff\u65f6\uff0c\u9ed8\u8ba4\u4ece\u5934\u90e8\u8fdb\u884c VNode \u7684\u5bf9\u6bd4\u548c\u590d\u7528\u3002\u53d1\u73b0 j=0 \u6307\u5411\u7684\u65b0\u65e7 VNode \u7684 key \u503c\u4e0d\u540c\uff0c\u5219\u653e\u5f03\u4ece\u5934\u90e8 Diff\uff0c\u8f6c\u800c\u4ece\u5c3e\u90e8\u5f00\u59cb\u8fdb\u884c Diff\u3002\u4ece\u5c3e\u90e8\u8fdb\u884cDiff\u65f6\uff0c\u53d1\u73b0\u65b0\u65e7 VNode \u90fd\u662fP3\uff0c\u4e8e\u662f\u590d\u7528P3\uff0c\u53ea\u5bf9P3\u8fdb\u884c patch \u66f4\u65b0\u5373\u53ef\u3002\u540c\u65f6\uff0c\u8ba9 <code>newEnd--<\/code> \u548c <code>oldEnd--<\/code>\uff0c\u4e3a\u7b2c2\u6b21Diff\u505a\u597d\u51c6\u5907\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627134805537.png\" alt=\"image-20230627134805537\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p>\u7b2c2\u6b21Diff\u65f6\uff0c<code>newEnd=2<\/code> \u4e14 <code>oldEnd=1<\/code>\uff0c\u5b83\u4eec\u6240\u6307\u5411\u7684\u65b0\u65e7 VNode \u90fd\u662fP2\uff0ckey \u503c\u4e00\u6837\uff0c\u53ef\u4ee5\u590d\u7528\uff0c\u4e8e\u662f\u5bf9P2\u8fdb\u884c patch \u66f4\u65b0\u3002\u540c\u65f6\u8ba9 <code>newEnd--<\/code> \u548c <code>oldEnd--<\/code>\uff0c\u4e3a\u7b2c3\u6b21Diff\u505a\u597d\u51c6\u5907\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627135107637.png\" alt=\"image-20230627135107637\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p>\u7b2c3\u6b21Diff\u65f6\uff0c<code>newEnd=1<\/code> \u4e14 <code>oldEnd=0<\/code>\uff0c\u5b83\u4eec\u6240\u6307\u5411\u7684\u65b0\u65e7 VNode \u90fd\u662fP1\uff0ckey \u503c\u4e00\u6837\uff0c\u53ef\u4ee5\u590d\u7528\uff0c\u4e8e\u662f\u5bf9P1\u8fdb\u884c patch \u66f4\u65b0\u3002\u540c\u65f6\u8ba9 <code>newEnd--<\/code> \u548c <code>oldEnd--<\/code>\uff0c\u4e3a\u7b2c4\u6b21Diff\u505a\u597d\u51c6\u5907\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627135203616.png\" alt=\"image-20230627135203616\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p>\u7b2c4\u6b21Diff\u65f6\uff0c<code>newEnd=0<\/code> \u4e14 <code>oldEnd=-1<\/code>\uff0c\u540c\u65f6 <code>j=0<\/code>\u3002\u7ecf\u8fc7\u5206\u6790\u6211\u4eec\u53d1\u73b0\uff1a<\/p>\n<ul>\n<li><code>oldEnd &lt; j<\/code>\uff0c\u8bf4\u660e\u65e7 VNode \u5df2\u7ecf\u5904\u7406\u5b8c\u6bd5<\/li>\n<li><code>newEnd &gt;= j<\/code>\uff0c\u8bf4\u660e\u65b0 VNode \u5c1a\u672a\u5904\u7406\u5b8c\uff0c\u8bc1\u660e\u8fd9\u4e9b\u5c1a\u672a\u5904\u7406\u5b8c\u7684\u65b0 Node \u662f\u65b0\u589e\u7684\uff0c\u53ea\u9700\u521b\u5efa\u5e76\u6dfb\u52a0\u5230P1\u4e4b\u524d\u5373\u53ef<\/li>\n<\/ul>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627135552658.png\" alt=\"image-20230627135552658\" style=\"zoom:80%;\" \/>\n<\/li>\n<\/ol>\n<blockquote>\n<p>\u6b64\u6b21 Diff \u8fc7\u7a0b\u4e2d\uff0c\u5b8c\u5168\u590d\u7528\u4e86 P1  &#8211; P3 \u8fd9\u4e09\u4e2a\u8282\u70b9\uff0c\u53ea\u65b0\u5efa\u4e86 P4 \u8282\u70b9\u3002<\/p>\n<\/blockquote>\n<h4>7. \u62d3\u5c55\uff1akey \u503c\u66f4\u65b0\u7b56\u7565\uff08\u5728\u4e2d\u95f4\u65b0\u589e\uff09<\/h4>\n<ol>\n<li>\n<p>\u521d\u59cb\u72b6\u6001\u4e0b\uff0c\u5b9a\u4e49\u4e09\u4e2a\u53d8\u91cf\uff0c\u5206\u522b\u6307\u5411\u5934\u90e8\u548c\u4e24\u4e2a\u5c3e\u90e8\u8282\u70b9\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627141345513.png\" alt=\"image-20230627141345513\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p>\u5148\u4ece\u5934\u90e8\u8fdb\u884c Diff \u6bd4\u8f83\uff0c\u5982\u679c key \u503c\u76f8\u540c\uff0c\u5219\u8fdb\u884c patch \u66f4\u65b0\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627141435718.png\" alt=\"image-20230627141435718\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p>\u7b2c3\u6b21Diff\u65f6 <code>j=2<\/code>\uff0c\u6b64\u65f6\u65b0 VNode \u662fP4\uff0c\u65e7 VNode \u662fP3\uff0ckey \u503c\u4e0d\u540c\uff0c\u5219\u4ece\u5c3e\u90e8\u5f00\u59cb Diff\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627141606048.png\" alt=\"image-20230627141606048\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p>\u7b2c4\u6b21Diff\u65f6\uff0c<code>newEnd=2<\/code> \u4e14 <code>oldEnd=1<\/code>\uff0c\u540c\u65f6 <code>j=2<\/code>\u3002\u7ecf\u8fc7\u5206\u6790\u6211\u4eec\u53d1\u73b0\uff1a<\/p>\n<ul>\n<li><code>oldEnd &lt; j<\/code>\uff0c\u8bf4\u660e\u65e7 VNode \u5df2\u7ecf\u5904\u7406\u5b8c\u6bd5<\/li>\n<li><code>newEnd &gt;= j<\/code>\uff0c\u8bf4\u660e\u65b0 VNode \u5c1a\u672a\u5904\u7406\u5b8c\uff0c\u8bc1\u660e\u8fd9\u4e9b\u5c1a\u672a\u5904\u7406\u5b8c\u7684\u65b0 Node \u662f\u65b0\u589e\u7684\uff0c\u53ea\u9700\u521b\u5efa\u5e76\u6dfb\u52a0\u5230P3\u4e4b\u524d\u5373\u53ef<\/li>\n<\/ul>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627141750761.png\" alt=\"image-20230627141750761\" style=\"zoom:80%;\" \/>\n<\/li>\n<\/ol>\n<blockquote>\n<p>\u6b64\u6b21 Diff \u8fc7\u7a0b\u4e2d\uff0c\u5b8c\u5168\u590d\u7528\u4e86 P1-P3 \u8282\u70b9\uff0c\u53ea\u65b0\u5efa\u4e86\u4e00\u4e2a P4 \u8282\u70b9\u3002<\/p>\n<\/blockquote>\n<h4>8. \u62d3\u5c55\uff1akey \u503c\u66f4\u65b0\u7b56\u7565\uff08\u5220\u9664\u5143\u7d20\uff09<\/h4>\n<ol>\n<li>\n<p>\u521d\u59cb\u72b6\u6001\u4e0b\uff0c\u5b9a\u4e49\u4e09\u4e2a\u53d8\u91cf\uff0c\u5206\u522b\u6307\u5411\u5934\u90e8\u548c\u4e24\u4e2a\u5c3e\u90e8\u8282\u70b9\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627142838470.png\" alt=\"image-20230627142838470\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p>\u5148\u4ece\u5934\u90e8\u8fdb\u884c\u6bd4\u8f83\uff0c\u5982\u679c key \u503c\u76f8\u540c\uff0c\u5219\u8fdb\u884c patch \u66f4\u65b0\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627142934406.png\" alt=\"image-20230627142934406\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p>\u7b2c3\u6b21Diff\u65f6 <code>j=2<\/code>\uff0c\u6b64\u65f6\u65b0 VNode \u662fP4\uff0c\u65e7 VNode \u662fP3\uff0ckey \u503c\u4e0d\u540c\uff0c\u5219\u4ece\u5c3e\u90e8\u5f00\u59cb Diff\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627143034292.png\" alt=\"image-20230627143034292\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p>\u7b2c4\u6b21Diff\u65f6\uff0c<code>newEnd=1<\/code> \u4e14 <code>oldEnd=2<\/code>\uff0c\u540c\u65f6 <code>j=2<\/code>\u3002\u7ecf\u8fc7\u5206\u6790\u6211\u4eec\u53d1\u73b0\uff1a<\/p>\n<ul>\n<li><code>newEnd &lt; j<\/code>\uff0c\u8bf4\u660e\u65b0 VNode \u5df2\u7ecf\u5904\u7406\u5b8c\u6bd5<\/li>\n<li><code>oldEnd &gt;= j<\/code>\uff0c\u8bf4\u660e\u65e7 VNode \u5c1a\u672a\u5904\u7406\u5b8c\uff0c\u8bc1\u660e\u8fd9\u4e9b\u5c1a\u672a\u5904\u7406\u5b8c\u7684\u65e7 Node \u662f\u591a\u4f59\u7684\uff0c\u53ea\u9700\u5220\u9664\u5b83\u4eec\u5373\u53ef<\/li>\n<\/ul>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627143225964.png\" alt=\"image-20230627143225964\" style=\"zoom:80%;\" \/>\n<\/li>\n<\/ol>\n<blockquote>\n<p>\u6b64\u6b21 Diff \u8fc7\u7a0b\u4e2d\uff0c\u5b8c\u5168\u590d\u7528\u4e86 P1\uff0cP2\uff0cP4 \u8fd9\u4e09\u4e2a\u8282\u70b9\uff0c\u53ea\u5220\u9664\u4e86\u4e00\u4e2a P3 \u8282\u70b9\u3002<\/p>\n<\/blockquote>\n<h4>9. \u62d3\u5c55\uff1akey \u503c\u66f4\u65b0\u7b56\u7565\uff08\u79fb\u52a8\u5143\u7d20\uff09<\/h4>\n<p>\u5728\u7406\u60f3\u72b6\u6001\u4e0b\uff0cDiff \u7b97\u6cd5\u53ea\u9700\u8981\u7b80\u5355\u7684\u6302\u8f7d\u6216\u5378\u8f7d\u8282\u70b9\u5373\u53ef\uff0c\u4f46\u5728\u590d\u6742\u60c5\u51b5\u4e0b\uff0c\u7b80\u5355\u7684\u6302\u8f7d\u548c\u5378\u8f7d\u8282\u70b9\u53ef\u80fd\u65e0\u6cd5\u5904\u7406\u5230\u6240\u6709\u7684\u8282\u70b9\uff0c\u4f8b\u5982\uff1a<\/p>\n<ol>\n<li>\n<p>\u521d\u59cb\u72b6\u6001\u5982\u4e0b\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627164509899.png\" alt=\"image-20230627164509899\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p>\u8fdb\u884c<strong>\u5148\u5934\u540e\u5c3e<\/strong>\u7684 Diff \u8fc7\u7a0b\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627164552253.png\" alt=\"image-20230627164552253\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p>\u5f53\u5934\u548c\u5c3e\u90fd\u5904\u7406\u5b8c\u6210\u540e\uff0c\u6211\u4eec\u53d1\u73b0\u8fd8\u5269\u4e0b\u4e86\u5f88\u591a<strong>\u4e2d\u95f4\u7684\u8282\u70b9<\/strong>\u6ca1\u6709\u88ab\u5904\u7406\u5230\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627164723129.png\" alt=\"image-20230627164723129\" style=\"zoom:80%;\" \/>\n<\/li>\n<\/ol>\n<p>\u4e3a\u4e86\u8fdb\u4e00\u6b65\u5904\u7406\u4e2d\u95f4\u8fd9\u4e9b\u5269\u4f59\u7684\u8282\u70b9\uff0c\u6211\u4eec\u9700\u8981\u4e86\u89e3\u4e00\u4e0b Diff \u7b97\u6cd5\u4e2d<strong>\u6700\u6838\u5fc3<\/strong>\u3001<strong>\u6700\u91cd\u8981<\/strong>\u7684\u5185\u5bb9\uff1a<\/p>\n<ol>\n<li>\n<p><strong>\u4e3a\u65b0 VNode \u4e2d\u672a\u5904\u7406\u7684\u5143\u7d20\u5efa\u7acb\u7d22\u5f15\u8868<\/strong>\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627165245435.png\" alt=\"image-20230627165245435\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p><strong>\u5faa\u73af\u65e7 VNode\uff0c\u5224\u65ad\u662f\u5426\u9700\u8981\u8fdb\u884c\u79fb\u52a8<\/strong>\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627165347428.png\" alt=\"image-20230627165347428\" style=\"zoom:80%;\" \/><\/p>\n<ol start=\"3\">\n<li>\n<p><strong>\u521b\u5efa source \u6570\u7ec4\uff0c\u7528\u6765\u8bb0\u5f55\u65b0 VNode \u5728\u65e7 VNode \u4e2d\u5bf9\u5e94\u7684\u771f\u5b9e\u7684\u7d22\u5f15\u4f4d\u7f6e<\/strong>\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627165522202.png\" alt=\"image-20230627165522202\" style=\"zoom:80%;\" \/>\n<\/li>\n<\/ol>\n<\/li>\n<li>\n<p><strong>\u5faa\u73af\u65e7 VNode\uff0c\u586b\u5145 source \u6570\u7ec4<\/strong>\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627165618872.png\" alt=\"image-20230627165618872\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p><strong>\u6839\u636e source \u6570\u7ec4\u5f97\u5230\u6700\u957f\u9012\u589e\u5b50\u5e8f\u5217\u7684\u7d22\u5f15\u6570\u7ec4<\/strong>\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627165725157.png\" alt=\"image-20230627165725157\" style=\"zoom:80%;\" \/>\n<\/li>\n<li>\n<p><strong>\u5012\u5e8f\u5faa\u73af\u6bcf\u4e00\u4e2a\u65b0 VNode \u8282\u70b9\uff0c\u6839\u636e\u4e0d\u540c\u7684\u6761\u4ef6\u5bf9 DOM \u8fdb\u884c\u521b\u5efa\u6216\u79fb\u52a8<\/strong>\uff1a<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/www.escook.cn\/wp-content\/uploads\/2023\/07\/image-20230627165946000.png\" alt=\"image-20230627165946000\" style=\"zoom:80%;\" \/>\n<\/li>\n<\/ol>\n<blockquote>\n<p>\u7248\u6743\u5f52\u4f5c\u8005 <strong>\u00a9\u5218\u9f99\u5bbe<\/strong> \u6240\u6709\uff0c\u672c\u6587\u7ae0\u672a\u7ecf\u4f5c\u8005\u5141\u8bb8\uff0c\u7981\u6b62\u79c1\u81ea\u8f6c\u8f7d\uff01<\/p>\n<\/blockquote>\n","protected":false},"excerpt":{"rendered":"<p>\u7248\u6743\u5f52\u4f5c\u8005 \u00a9\u5218\u9f99\u5bbe \u6240\u6709\uff0c\u672c\u6587\u7ae0\u672a\u7ecf\u4f5c\u8005\u5141\u8bb8\uff0c\u7981\u6b62\u79c1\u81ea\u8f6c\u8f7d\uff01 1. \u5728 HTML \u7f51\u9875\u4e2d\u4f7f\u7528 vue3 \u76843\u4e2a\u57fa\u672c\u6b65\u9aa4 \u901a\u8fc7 script \u6807\u7b7e\u7684 src \u5c5e\u6027\uff0c\u5728\u5f53\u524d\u7f51\u9875\u4e2d\u5168\u5c40\u5f15\u5165 vue3 \u7684\u811a\u672c\u6587\u4ef6\uff1a &lt;script src=&quot;https:\/\/unpkg.com\/vue@3\/dist\/vue.global.js&quot;&gt;&lt;\/script&gt; \u521b\u5efa vue3 \u7684\u5355\u9875\u9762\u5e94\u7528\u7a0b\u5e8f\u5b9e\u4f8b\uff1a \/\/ 2.1 \u4ece Vue \u5bf9\u8c61\u4e2d\u89e3\u6784\u51fa createApp \u51fd\u6570 const { createApp } = Vue \/\/ 2.2 \u8c03\u7528 createApp \u8fd9\u4e2a\u51fd\u6570\uff0c\u5c31\u80fd\u591f\u521b\u5efa\u51fa\u4e00\u4e2a\u5355\u9875\u9762\u5e94\u7528\u7a0b\u5e8f\u7684\u5b9e\u4f8b const app = createApp() \/\/ 2.3 \u8c03\u7528 app \u5b9e\u4f8b\u5bf9\u8c61\u4e0a\u7684 mount() \u51fd\u6570\uff0c \/\/ \u6307\u5b9a\u5355\u9875\u9762\u5e94\u7528\u7a0b\u5e8f app\uff0c\u5b9e\u9645\u8981\u63a7\u5236\u9875\u9762\u4e0a\u54ea\u4e2a\u533a\u57df\u7684\u6e32\u67d3 app.mount(&#8216;#app&#8217;) \u58f0\u660e vue3 \u7684\u5355\u9875\u9762\u5e94\u7528\u7a0b\u5e8f\u5b9e\u4f8b\uff0c\u5b9e\u9645\u8981\u63a7\u5236\u7684\u9875\u9762\u533a\u57df\uff1a &lt;!&#8211; \u6ce8\u610f\uff1a\u5982\u679c\u5185\u5bb9\u4e3a\u7a7a\uff0c\u5219 vue3 \u4f1a\u5728\u63d0\u793a\u4e00\u4e2a\u8b66\u544a\u6d88\u606f\uff1a [Vue warn]: Component is missing template or render function. at &lt;App&gt; &#8211;&gt; &lt;div id=&quot;app&quot;&gt;&lt;\/div&gt; 2. \u5b9a\u4e49\u548c\u6e32\u67d3\u6570\u636e \u5728\u8c03\u7528 createApp() \u51fd\u6570\u65f6\uff0c\u53ef\u4ee5\u63d0\u4f9b\u4e00\u4e2a\u5bf9\u8c61\u4f5c\u4e3a\u914d\u7f6e\u53c2\u6570\uff0c\u4f8b\u5982\uff1a const app = createApp({ \/*\u914d\u7f6e\u5bf9\u8c61*\/ }) \u5982\u679c\u60f3\u63d0\u4f9b\u8981\u6e32\u67d3\u7684\u6570\u636e\uff0c\u53ef\u4ee5\u5728\u6b65\u9aa41\u7684\u914d\u7f6e\u5bf9\u8c61\u4e2d\uff0c\u901a\u8fc7 data \u8282\u70b9\u63d0\u4f9b\u6e32\u67d3\u671f\u95f4\u8981\u4f7f\u7528\u7684\u6570\u636e\uff1a const app = createApp({ \/\/ 2.1 \u6ce8\u610f\uff1adata \u8282\u70b9\u662f\u4e00\u4e2a\u51fd\u6570 data() { \/\/ 2.2 \u5728 data \u51fd\u6570\u5185\u90e8\uff0creturn \u7684\u8fd9\u4e2a\u5bf9\u8c61\uff0c\u5c31\u662f\u6570\u636e\u5bf9\u8c61\uff0c \/\/ \u8981\u6e32\u67d3\u7684\u6570\u636e\uff0c\u53ef\u4ee5\u76f4\u63a5\u5199\u5230\u8fd9\u4e2a\u5bf9\u8c61\u4e2d\uff0c\u4f8b\u5982 return { name: &#8216;zs&#8217; } return {} } }) \u5728\u6b65\u9aa42\u7684 data \u8282\u70b9\u4e2d\uff0c\u5b9a\u4e49\u4e00\u4e2a\u540d\u4e3a name \u7684\u6570\u636e\uff0c\u503c\u662f liulongbin\uff1a const app = createApp({ data() { return { name: &#8216;liulongbin&#8217; } } }) \u5728 vue3 \u63a7\u5236\u7684\u6a21\u677f\u7ed3\u6784\u4e2d\uff0c\u4f7f\u7528 {{ \u6570\u636e\u540d }} \u8bed\u6cd5\uff0c\u628a\u6570\u636e\u6e32\u67d3\u51fa\u6765\uff1a &lt;div id=&quot;app&quot;&gt; &lt;h1&gt;\u5927\u5bb6\u597d\uff0c\u6211\u662f\uff1a{{ name }}&lt;\/h1&gt; &lt;\/div&gt; \u62d3\u5c55\uff1a\u5f53\u6211\u4eec\u4fee\u6539 data \u8282\u70b9\u4e0b\u7684\u6570\u636e\u540e\uff0c\u5373\u53ef\u770b\u5230\u9875\u9762\u4e0a\u7684 HTML \u5185\u5bb9\u4f1a\u81ea\u52a8\u88ab\u5237\u65b0\u3002\u8fd9\u5c31\u662f vue \u7684\u5f3a\u5927\u4e4b\u5904\uff1a\u6570\u636e\u9a71\u52a8\u89c6\u56fe\u3002\u4fee\u6539 data \u6570\u636e\u7684\u793a\u4f8b\u4ee3\u7801\u5982\u4e0b\uff1a app._instance.proxy.name = &#039;escook&#039; 3. vue3 \u4e2d\u5e38\u7528\u7684\u6e32\u67d3\u6307\u4ee4 \u5728 vue \u4e2d\uff0c\u6307\u4ee4\u662f\u5e26\u6709 v- \u524d\u7f00\u7684\u7279\u6b8a attribute\uff0c\u5b83\u662f vue \u63d0\u4f9b\u7684\u7279\u6b8a\u8bed\u6cd5\uff0c\u5927\u5bb6\u6709\u5fc5\u8981\u638c\u63e1 vue \u4e2d\u5e38\u7528\u6307\u4ee4\u7684\u4f7f\u7528\u3002 \u6307\u4ee4\u80fd\u591f\u8f85\u52a9\u524d\u7aef\u7a0b\u5e8f\u5458\u9ad8\u6548\u5730\u628a\u6570\u636e\u6e32\u67d3\u4e3a HTML \u7684\u7ed3\u6784\uff0c\u800c\u7a0b\u5e8f\u5458\u4e0d\u9700\u8981\u8c03\u7528\u4efb\u4f55\u64cd\u4f5c DOM \u7684 API\u3002 3.0 \u5e38\u7528\u6307\u4ee4\u7684\u5206\u7c7b \u5185\u5bb9\u6e32\u67d3\u6307\u4ee4 \u5c5e\u6027\u7ed1\u5b9a\u6307\u4ee4 \u53cc\u5411\u7ed1\u5b9a\u6307\u4ee4 \u6761\u4ef6\u6e32\u67d3\u6307\u4ee4 \u4e8b\u4ef6\u7ed1\u5b9a\u6307\u4ee4 \u5217\u8868\u6e32\u67d3\u6307\u4ee4 3.1 \u5185\u5bb9\u6e32\u67d3\u6307\u4ee4 1. \u63d2\u503c\u8868\u8fbe\u5f0f \u63d2\u503c\u8868\u8fbe\u5f0f\uff08\u53c8\u53eb\u505a\uff1aMustache\uff09\u7684\u8bed\u6cd5\u4e3a {{ }}\uff0cvue \u5728\u89e3\u6790\u6a21\u677f\u671f\u95f4\uff0c\u4f1a\u628a {{ }} \u6240\u5728\u7684\u4f4d\u7f6e\uff0c\u66ff\u6362\u4e3a\u5bf9\u5e94\u7684\u6570\u636e\u503c\uff0c\u4f8b\u5982\uff1a &lt;h1&gt;\u5927\u5bb6\u597d\uff0c\u6211\u662f\uff1a{{ name }}&lt;\/h1&gt; vue \u4f1a\u628a name \u7684\u503c\uff0c\u66ff\u6362\u5230 {{ name }} \u6240\u5728\u7684\u4f4d\u7f6e\u3002 \u6ce8\u610f\uff1a\u63d2\u503c\u8868\u8fbe\u5f0f {{ }} \u662f\u552f\u4e00\u4e00\u4e2a\u4e0d\u4ee5 v- \u524d\u7f00\u5f00\u5934\u7684\u6307\u4ee4\u3002 2. v-text v-text \u6307\u4ee4\u7528\u6765\u586b\u5145 HTML \u5143\u7d20\u7684\u5185\u5bb9\uff0c\u5982\u679c HTML \u5143\u7d20\u5185\u90e8\u6709\u5176\u5b83\u5185\u5bb9\u5b58\u5728\uff0c\u5219\u4f1a\u88ab\u8986\u76d6\u6389\u3002\u8bed\u6cd5\u683c\u5f0f\u5982\u4e0b\uff1a &lt;h3 v-text=&quot;msg&quot;&gt;\u662f\u5144\u5f1f\u5c31\u6765&lt;\/h3&gt; \u5bf9\u5e94\u7684\u6570\u636e\u4e3a\uff1a const app = createApp({ data() { return { msg: &#039;\u780d\u6211\u5427&#039; } } }) \u6ce8\u610f\uff1a\u7531\u4e8e v-text \u6307\u4ee4\u5b58\u5728\u8986\u76d6\u5df2\u6709\u5185\u5bb9\u7684\u95ee\u9898\uff0c\u6240\u4ee5\u5728\u5b9e\u9645\u5f00\u53d1\u4e2d\u5b83\u5f88\u5c11\u88ab\u7528\u5230\u3002\u6700\u5e38\u7528\u7684\u8fd8\u662f {{ }} \u63d2\u503c\u8868\u8fbe\u5f0f\uff0c\u56e0\u4e3a\u5b83\u53ea\u662f\u5360\u4f4d\u7b26\uff0c\u4e0d\u4f1a\u8986\u76d6\u5df2\u6709\u5185\u5bb9\u3002 3. v-html v-html \u6307\u4ee4\u7528\u6765\u6e32\u67d3\u5e26\u6709 HTML \u6807\u8bb0\u7684\u6587\u672c\u5185\u5bb9\uff0c\u5b83\u53ef\u4ee5&#8230;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[6],"tags":[],"class_list":["post-262","post","type-post","status-publish","format-standard","hentry","category-vue"],"_links":{"self":[{"href":"https:\/\/www.escook.cn\/index.php\/wp-json\/wp\/v2\/posts\/262","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.escook.cn\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.escook.cn\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.escook.cn\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.escook.cn\/index.php\/wp-json\/wp\/v2\/comments?post=262"}],"version-history":[{"count":39,"href":"https:\/\/www.escook.cn\/index.php\/wp-json\/wp\/v2\/posts\/262\/revisions"}],"predecessor-version":[{"id":434,"href":"https:\/\/www.escook.cn\/index.php\/wp-json\/wp\/v2\/posts\/262\/revisions\/434"}],"wp:attachment":[{"href":"https:\/\/www.escook.cn\/index.php\/wp-json\/wp\/v2\/media?parent=262"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.escook.cn\/index.php\/wp-json\/wp\/v2\/categories?post=262"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.escook.cn\/index.php\/wp-json\/wp\/v2\/tags?post=262"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}