{"id":298,"date":"2026-03-19T22:33:43","date_gmt":"2026-03-19T14:33:43","guid":{"rendered":"https:\/\/www.resilence.cn\/?p=298"},"modified":"2026-03-19T22:33:43","modified_gmt":"2026-03-19T14:33:43","slug":"day-27-%e6%a8%a1%e5%9d%97%e5%8c%96%e5%bc%80%e5%8f%91","status":"publish","type":"post","link":"https:\/\/www.resilence.cn\/?p=298","title":{"rendered":"Day-27-\u6a21\u5757\u5316\u5f00\u53d1"},"content":{"rendered":"<h1>Day 27: \u6a21\u5757\u5316\u5f00\u53d1<\/h1>\n<blockquote>\n<p>\ud83d\udcc5 \u65e5\u671f: 2026\u5e7403\u670819\u65e5<br \/>\n\ud83c\udfaf \u5b66\u4e60\u76ee\u6807: \u638c\u63e1 ES6 \u6a21\u5757\u5316\uff0c\u5b66\u4f1a\u7ec4\u7ec7\u548c\u7ba1\u7406\u5927\u578b\u9879\u76ee\u4ee3\u7801<br \/>\n\u23f1\ufe0f \u9884\u8ba1\u7528\u65f6: 2-3 \u5c0f\u65f6<br \/>\n\ud83d\udcc2 \u5206\u7c7b: 10-\u73b0\u4ee3JavaScript<\/p>\n<\/blockquote>\n<hr>\n<h2>\ud83c\udfaf \u5b66\u4e60\u76ee\u6807<\/h2>\n<p>\u901a\u8fc7\u4eca\u5929\u7684\u5b66\u4e60\uff0c\u4f60\u5c06\uff1a<\/p>\n<ol>\n<li><strong>\u7406\u89e3\u6a21\u5757\u5316\u601d\u60f3<\/strong>\uff1a\u4e3a\u4ec0\u4e48\u9700\u8981\u6a21\u5757\u5316<\/li>\n<li><strong>\u638c\u63e1 ES6 \u6a21\u5757\u8bed\u6cd5<\/strong>\uff1aexport\u3001import\u3001default<\/li>\n<li><strong>\u5b66\u4f1a\u4ee3\u7801\u7ec4\u7ec7<\/strong>\uff1a\u6587\u4ef6\u7ed3\u6784\u3001\u547d\u540d\u89c4\u8303<\/li>\n<li><strong>\u5b9e\u8df5\u4f9d\u8d56\u7ba1\u7406<\/strong>\uff1anpm\u3001yarn\u3001package.json<\/li>\n<li><strong>\u5e94\u7528\u5b9e\u6218\u573a\u666f<\/strong>\uff1a\u6784\u5efa\u53ef\u7ef4\u62a4\u7684\u5927\u578b\u9879\u76ee<\/li>\n<\/ol>\n<hr>\n<h2>\ud83d\udca1 \u6838\u5fc3\u6982\u5ff5<\/h2>\n<h3>1. \u4ec0\u4e48\u662f\u6a21\u5757\u5316<\/h3>\n<p><strong>\u6a21\u5757\u5316<\/strong>\u662f\u5c06\u4ee3\u7801\u62c6\u5206\u6210\u72ec\u7acb\u3001\u53ef\u590d\u7528\u7684\u5355\u5143\uff08\u6a21\u5757\uff09\uff0c\u6bcf\u4e2a\u6a21\u5757\u6709\u81ea\u5df1\u7684\u4f5c\u7528\u57df\uff0c\u53ea\u66b4\u9732\u5fc5\u8981\u7684\u63a5\u53e3\u3002<\/p>\n<pre><code class=\"language-javascript\">\/\/ \u274c \u6ca1\u6709\u6a21\u5757\u5316\uff1a\u5168\u5c40\u53d8\u91cf\u6c61\u67d3\nvar name = &quot;\u5f20\u4e09&quot;;\nvar age = 25;\n\n\/\/ \u591a\u4e2a\u811a\u672c\u6587\u4ef6\u53ef\u80fd\u4e92\u76f8\u8986\u76d6\n\/\/ \u53d8\u91cf\u540d\u51b2\u7a81\u3001\u4f9d\u8d56\u6df7\u4e71\n\n\/\/ \u2705 \u6a21\u5757\u5316\uff1a\u72ec\u7acb\u4f5c\u7528\u57df\n\/\/ user.js\nexport const name = &quot;\u5f20\u4e09&quot;;\nexport const age = 25;\n\n\/\/ main.js\nimport { name, age } from '.\/user.js';\n<\/code><\/pre>\n<h3>2. \u4e3a\u4ec0\u4e48\u9700\u8981\u6a21\u5757\u5316<\/h3>\n<p><strong>\u6a21\u5757\u5316\u7684\u597d\u5904<\/strong>\uff1a<\/p>\n<ol>\n<li><strong>\u907f\u514d\u547d\u540d\u51b2\u7a81<\/strong>\uff1a\u6bcf\u4e2a\u6a21\u5757\u6709\u72ec\u7acb\u4f5c\u7528\u57df<\/li>\n<li><strong>\u63d0\u9ad8\u4ee3\u7801\u590d\u7528<\/strong>\uff1a\u6a21\u5757\u53ef\u4ee5\u5728\u591a\u5904\u5f15\u7528<\/li>\n<li><strong>\u4fbf\u4e8e\u7ef4\u62a4<\/strong>\uff1a\u804c\u8d23\u6e05\u6670\u3001\u6613\u4e8e\u5b9a\u4f4d\u95ee\u9898<\/li>\n<li><strong>\u6309\u9700\u52a0\u8f7d<\/strong>\uff1a\u6d4f\u89c8\u5668\u53ea\u52a0\u8f7d\u9700\u8981\u7684\u6a21\u5757<\/li>\n<li><strong>\u66f4\u597d\u7684\u534f\u4f5c<\/strong>\uff1a\u56e2\u961f\u6210\u5458\u5e76\u884c\u5f00\u53d1\u4e0d\u540c\u6a21\u5757<\/li>\n<\/ol>\n<h3>3. ES6 \u6a21\u5757 vs CommonJS<\/h3>\n<table>\n<thead>\n<tr>\n<th>\u7279\u6027<\/th>\n<th>ES6 \u6a21\u5757<\/th>\n<th>CommonJS<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>\u8bed\u6cd5<\/td>\n<td><code>export<\/code> \/ <code>import<\/code><\/td>\n<td><code>module.exports<\/code> \/ <code>require<\/code><\/td>\n<\/tr>\n<tr>\n<td>\u52a0\u8f7d\u65b9\u5f0f<\/td>\n<td>\u7f16\u8bd1\u65f6\u52a0\u8f7d<\/td>\n<td>\u8fd0\u884c\u65f6\u52a0\u8f7d<\/td>\n<\/tr>\n<tr>\n<td>\u8f93\u51fa<\/td>\n<td>\u503c\u7684\u5f15\u7528<\/td>\n<td>\u503c\u7684\u62f7\u8d1d<\/td>\n<\/tr>\n<tr>\n<td>\u4f7f\u7528\u573a\u666f<\/td>\n<td>\u6d4f\u89c8\u5668 + Node.js<\/td>\n<td>\u4e3b\u8981 Node.js<\/td>\n<\/tr>\n<tr>\n<td>\u652f\u6301<\/td>\n<td>\u539f\u751f\u652f\u6301<\/td>\n<td>\u9700\u8981\u6784\u5efa\u5de5\u5177<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<hr>\n<h2>\ud83d\udee0\ufe0f \u8bed\u6cd5\u8be6\u89e3<\/h2>\n<h3>1. export &#8211; \u5bfc\u51fa<\/h3>\n<h4>\u547d\u540d\u5bfc\u51fa\uff08Named Exports\uff09<\/h4>\n<pre><code class=\"language-javascript\">\/\/ utils.js\n\/\/ \u5bfc\u51fa\u53d8\u91cf\nexport const PI = 3.14159;\n\n\/\/ \u5bfc\u51fa\u51fd\u6570\nexport function add(a, b) {\n    return a + b;\n}\n\n\/\/ \u5bfc\u51fa\u7c7b\nexport class Calculator {\n    constructor() {\n        this.result = 0;\n    }\n    \n    add(num) {\n        this.result += num;\n        return this;\n    }\n}\n\n\/\/ \u4e5f\u53ef\u4ee5\u5148\u5b9a\u4e49\u540e\u5bfc\u51fa\nconst name = &quot;\u5de5\u5177\u6a21\u5757&quot;;\nfunction greet() {\n    console.log(&quot;Hello!&quot;);\n}\nexport { name, greet };\n\n\/\/ \u5bfc\u51fa\u65f6\u91cd\u547d\u540d\nexport { add as sum, greet as hello };\n<\/code><\/pre>\n<h4>\u9ed8\u8ba4\u5bfc\u51fa\uff08Default Export\uff09<\/h4>\n<pre><code class=\"language-javascript\">\/\/ calculator.js\n\/\/ \u6bcf\u4e2a\u6a21\u5757\u53ea\u80fd\u6709\u4e00\u4e2a\u9ed8\u8ba4\u5bfc\u51fa\nexport default class Calculator {\n    constructor() {\n        this.result = 0;\n    }\n    \n    add(num) {\n        this.result += num;\n        return this;\n    }\n}\n\n\/\/ \u6216\u8005\nclass Calculator {\n    \/\/ ...\n}\nexport default Calculator;\n\n\/\/ \u5bfc\u51fa\u8868\u8fbe\u5f0f\nexport default function(a, b) {\n    return a + b;\n}\n<\/code><\/pre>\n<h4>\u6df7\u5408\u5bfc\u51fa<\/h4>\n<pre><code class=\"language-javascript\">\/\/ \u540c\u65f6\u4f7f\u7528\u547d\u540d\u5bfc\u51fa\u548c\u9ed8\u8ba4\u5bfc\u51fa\nexport default class Calculator {\n    \/\/ ...\n}\n\nexport const VERSION = &quot;1.0.0&quot;;\nexport function help() {\n    console.log(&quot;\u4f7f\u7528\u5e2e\u52a9...&quot;);\n}\n<\/code><\/pre>\n<h3>2. import &#8211; \u5bfc\u5165<\/h3>\n<h4>\u5bfc\u5165\u547d\u540d\u5bfc\u51fa<\/h4>\n<pre><code class=\"language-javascript\">\/\/ main.js\n\/\/ \u5bfc\u5165\u7279\u5b9a\u7684\u5bfc\u51fa\nimport { PI, add, Calculator } from '.\/utils.js';\n\n\/\/ \u5bfc\u5165\u5e76\u91cd\u547d\u540d\nimport { add as sum, name as moduleName } from '.\/utils.js';\n\n\/\/ \u5bfc\u5165\u6240\u6709\u5bfc\u51fa\uff08\u7ed1\u5b9a\u5230\u5bf9\u8c61\uff09\nimport * as utils from '.\/utils.js';\nconsole.log(utils.PI);\nconsole.log(utils.add(1, 2));\n<\/code><\/pre>\n<h4>\u5bfc\u5165\u9ed8\u8ba4\u5bfc\u51fa<\/h4>\n<pre><code class=\"language-javascript\">\/\/ main.js\n\/\/ \u5bfc\u5165\u9ed8\u8ba4\u5bfc\u51fa\uff08\u4e0d\u9700\u8981\u5927\u62ec\u53f7\uff09\nimport Calculator from '.\/calculator.js';\n\nconst calc = new Calculator();\ncalc.add(5).add(3);\nconsole.log(calc.result);\n<\/code><\/pre>\n<h4>\u6df7\u5408\u5bfc\u5165<\/h4>\n<pre><code class=\"language-javascript\">\/\/ \u540c\u65f6\u5bfc\u5165\u9ed8\u8ba4\u5bfc\u51fa\u548c\u547d\u540d\u5bfc\u51fa\nimport Calculator, { VERSION, help } from '.\/calculator.js';\n<\/code><\/pre>\n<h4>\u53ea\u5bfc\u5165\u526f\u4f5c\u7528<\/h4>\n<pre><code class=\"language-javascript\">\/\/ \u6709\u4e9b\u6a21\u5757\u53ea\u6267\u884c\u526f\u4f5c\u7528\uff0c\u4e0d\u5bfc\u51fa\u4efb\u4f55\u5185\u5bb9\nimport '.\/polyfill.js';\nimport '.\/styles.css';\n<\/code><\/pre>\n<h3>3. \u52a8\u6001\u5bfc\u5165\uff08Dynamic Import\uff09<\/h3>\n<pre><code class=\"language-javascript\">\/\/ \u8fd0\u884c\u65f6\u52a8\u6001\u52a0\u8f7d\u6a21\u5757\nasync function loadModule() {\n    const { add } = await import('.\/utils.js');\n    console.log(add(1, 2));\n}\n\n\/\/ \u6309\u9700\u52a0\u8f7d\nbutton.addEventListener('click', async () =&gt; {\n    const module = await import('.\/heavy-module.js');\n    module.doSomething();\n});\n<\/code><\/pre>\n<hr>\n<h2>\ud83c\udfae \u5b9e\u6218\u793a\u4f8b<\/h2>\n<h3>\u793a\u4f8b 1\uff1a\u5de5\u5177\u6a21\u5757<\/h3>\n<pre><code class=\"language-javascript\">\/\/ utils\/string.js\n\/\/ \u5b57\u7b26\u4e32\u5de5\u5177\u51fd\u6570\nexport function capitalize(str) {\n    return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\nexport function truncate(str, length) {\n    return str.length &gt; length \n        ? str.slice(0, length) + '...' \n        : str;\n}\n\nexport function slugify(str) {\n    return str\n        .toLowerCase()\n        .trim()\n        .replace(\/\\s+\/g, '-')\n        .replace(\/[^\\w-]+\/g, '');\n}\n\n\/\/ utils\/date.js\n\/\/ \u65e5\u671f\u5de5\u5177\u51fd\u6570\nexport function formatDate(date, format = 'YYYY-MM-DD') {\n    const year = date.getFullYear();\n    const month = String(date.getMonth() + 1).padStart(2, '0');\n    const day = String(date.getDate()).padStart(2, '0');\n    \n    return format\n        .replace('YYYY', year)\n        .replace('MM', month)\n        .replace('DD', day);\n}\n\nexport function addDays(date, days) {\n    const result = new Date(date);\n    result.setDate(result.getDate() + days);\n    return result;\n}\n\n\/\/ utils\/index.js\n\/\/ \u7edf\u4e00\u5bfc\u51fa\u6240\u6709\u5de5\u5177\u6a21\u5757\nexport * from '.\/string.js';\nexport * from '.\/date.js';\n<\/code><\/pre>\n<h3>\u793a\u4f8b 2\uff1aAPI \u6a21\u5757<\/h3>\n<pre><code class=\"language-javascript\">\/\/ api\/config.js\n\/\/ API \u914d\u7f6e\nexport const BASE_URL = 'https:\/\/api.example.com';\nexport const TIMEOUT = 5000;\nexport const HEADERS = {\n    'Content-Type': 'application\/json',\n};\n\n\/\/ api\/request.js\n\/\/ HTTP \u8bf7\u6c42\u5c01\u88c5\nimport { BASE_URL, TIMEOUT, HEADERS } from '.\/config.js';\n\nexport async function request(endpoint, options = {}) {\n    const url = `${BASE_URL}${endpoint}`;\n    \n    const config = {\n        ...options,\n        headers: {\n            ...HEADERS,\n            ...options.headers,\n        },\n    };\n    \n    const controller = new AbortController();\n    const timeoutId = setTimeout(() =&gt; controller.abort(), TIMEOUT);\n    \n    try {\n        const response = await fetch(url, {\n            ...config,\n            signal: controller.signal,\n        });\n        \n        clearTimeout(timeoutId);\n        \n        if (!response.ok) {\n            throw new Error(`HTTP ${response.status}`);\n        }\n        \n        return await response.json();\n    } catch (error) {\n        clearTimeout(timeoutId);\n        throw error;\n    }\n}\n\n\/\/ api\/user.js\n\/\/ \u7528\u6237\u76f8\u5173 API\nimport { request } from '.\/request.js';\n\nexport async function getUser(id) {\n    return await request(`\/users\/${id}`);\n}\n\nexport async function createUser(data) {\n    return await request('\/users', {\n        method: 'POST',\n        body: JSON.stringify(data),\n    });\n}\n\nexport async function updateUser(id, data) {\n    return await request(`\/users\/${id}`, {\n        method: 'PUT',\n        body: JSON.stringify(data),\n    });\n}\n\nexport async function deleteUser(id) {\n    return await request(`\/users\/${id}`, {\n        method: 'DELETE',\n    });\n}\n<\/code><\/pre>\n<h3>\u793a\u4f8b 3\uff1a\u7ec4\u4ef6\u6a21\u5757<\/h3>\n<pre><code class=\"language-javascript\">\/\/ components\/Button.js\n\/\/ \u6309\u94ae\u7ec4\u4ef6\nimport '.\/styles\/button.css';\n\nexport class Button {\n    constructor({ text, onClick, variant = 'primary' }) {\n        this.text = text;\n        this.onClick = onClick;\n        this.variant = variant;\n        this.element = this.render();\n    }\n    \n    render() {\n        const button = document.createElement('button');\n        button.className = `btn btn-${this.variant}`;\n        button.textContent = this.text;\n        \n        button.addEventListener('click', this.onClick);\n        \n        return button;\n    }\n    \n    mount(parent) {\n        parent.appendChild(this.element);\n    }\n    \n    unmount() {\n        this.element.remove();\n    }\n}\n\n\/\/ components\/Modal.js\n\/\/ \u6a21\u6001\u6846\u7ec4\u4ef6\nexport class Modal {\n    constructor({ title, content, onClose }) {\n        this.title = title;\n        this.content = content;\n        this.onClose = onClose;\n        this.element = this.render();\n    }\n    \n    render() {\n        const modal = document.createElement('div');\n        modal.className = 'modal';\n        modal.innerHTML = `\n            &lt;div class=&quot;modal-overlay&quot;&gt;\n                &lt;div class=&quot;modal-content&quot;&gt;\n                    &lt;div class=&quot;modal-header&quot;&gt;\n                        &lt;h3&gt;${this.title}&lt;\/h3&gt;\n                        &lt;button class=&quot;modal-close&quot;&gt;&amp;times;&lt;\/button&gt;\n                    &lt;\/div&gt;\n                    &lt;div class=&quot;modal-body&quot;&gt;\n                        ${this.content}\n                    &lt;\/div&gt;\n                &lt;\/div&gt;\n            &lt;\/div&gt;\n        `;\n        \n        const closeBtn = modal.querySelector('.modal-close');\n        closeBtn.addEventListener('click', () =&gt; this.close());\n        \n        return modal;\n    }\n    \n    open() {\n        document.body.appendChild(this.element);\n    }\n    \n    close() {\n        this.element.remove();\n        if (this.onClose) this.onClose();\n    }\n}\n<\/code><\/pre>\n<hr>\n<h2>\ud83d\udcc2 \u9879\u76ee\u7ed3\u6784<\/h2>\n<h3>\u63a8\u8350\u7684\u6587\u4ef6\u7ec4\u7ec7\u65b9\u5f0f<\/h3>\n<pre><code>project\/\n\u251c\u2500\u2500 index.html              # \u5165\u53e3 HTML\n\u251c\u2500\u2500 main.js                 # \u5165\u53e3 JS\n\u251c\u2500\u2500 package.json            # \u9879\u76ee\u914d\u7f6e\n\u251c\u2500\u2500 src\/\n\u2502   \u251c\u2500\u2500 api\/                # API \u6a21\u5757\n\u2502   \u2502   \u251c\u2500\u2500 config.js\n\u2502   \u2502   \u251c\u2500\u2500 request.js\n\u2502   \u2502   \u2514\u2500\u2500 user.js\n\u2502   \u251c\u2500\u2500 components\/         # \u7ec4\u4ef6\u6a21\u5757\n\u2502   \u2502   \u251c\u2500\u2500 Button.js\n\u2502   \u2502   \u251c\u2500\u2500 Modal.js\n\u2502   \u2502   \u2514\u2500\u2500 index.js        # \u7edf\u4e00\u5bfc\u51fa\n\u2502   \u251c\u2500\u2500 utils\/              # \u5de5\u5177\u6a21\u5757\n\u2502   \u2502   \u251c\u2500\u2500 string.js\n\u2502   \u2502   \u251c\u2500\u2500 date.js\n\u2502   \u2502   \u2514\u2500\u2500 index.js\n\u2502   \u251c\u2500\u2500 styles\/             # \u6837\u5f0f\u6587\u4ef6\n\u2502   \u2502   \u2514\u2500\u2500 main.css\n\u2502   \u2514\u2500\u2500 assets\/             # \u9759\u6001\u8d44\u6e90\n\u2502       \u251c\u2500\u2500 images\/\n\u2502       \u2514\u2500\u2500 fonts\/\n\u2514\u2500\u2500 public\/                 # \u516c\u5171\u8d44\u6e90\n    \u2514\u2500\u2500 favicon.ico\n<\/code><\/pre>\n<h3>package.json \u914d\u7f6e<\/h3>\n<pre><code class=\"language-json\">{\n  &quot;name&quot;: &quot;my-project&quot;,\n  &quot;version&quot;: &quot;1.0.0&quot;,\n  &quot;type&quot;: &quot;module&quot;,\n  &quot;main&quot;: &quot;main.js&quot;,\n  &quot;scripts&quot;: {\n    &quot;start&quot;: &quot;vite&quot;,\n    &quot;build&quot;: &quot;vite build&quot;,\n    &quot;preview&quot;: &quot;vite preview&quot;\n  },\n  &quot;dependencies&quot;: {\n    &quot;axios&quot;: &quot;^1.6.0&quot;\n  },\n  &quot;devDependencies&quot;: {\n    &quot;vite&quot;: &quot;^5.0.0&quot;\n  }\n}\n<\/code><\/pre>\n<p><strong>\u6ce8\u610f<\/strong>\uff1a<code>&quot;type&quot;: &quot;module&quot;<\/code> \u544a\u8bc9 Node.js \u4f7f\u7528 ES6 \u6a21\u5757\u3002<\/p>\n<hr>\n<h2>\u26a0\ufe0f \u91cd\u8981\u6ce8\u610f\u4e8b\u9879<\/h2>\n<h3>1. \u6a21\u5757\u7684\u52a0\u8f7d\u987a\u5e8f<\/h3>\n<pre><code class=\"language-javascript\">\/\/ \u2705 \u6b63\u786e\uff1a\u5148\u5bfc\u5165\u540e\u4f7f\u7528\nimport { utils } from '.\/utils.js';\nconsole.log(utils.formatDate(new Date()));\n\n\/\/ \u274c \u9519\u8bef\uff1a\u5728\u5bfc\u5165\u524d\u4f7f\u7528\nconsole.log(utils.formatDate(new Date()));  \/\/ ReferenceError\nimport { utils } from '.\/utils.js';\n<\/code><\/pre>\n<h3>2. \u5faa\u73af\u4f9d\u8d56<\/h3>\n<pre><code class=\"language-javascript\">\/\/ a.js\nimport { foo } from '.\/b.js';\nexport const bar = 'bar';\n\n\/\/ b.js\nimport { bar } from '.\/a.js';\nexport const foo = 'foo';\n\n\/\/ \u26a0\ufe0f \u53ef\u80fd\u5bfc\u81f4 undefined\n\/\/ \u89e3\u51b3\u65b9\u6848\uff1a\u91cd\u6784\u4ee3\u7801\uff0c\u907f\u514d\u5faa\u73af\u4f9d\u8d56\n<\/code><\/pre>\n<h3>3. this \u7684\u6307\u5411<\/h3>\n<pre><code class=\"language-javascript\">\/\/ ES6 \u6a21\u5757\u4e2d\uff0c\u9876\u7ea7 this \u662f undefined\nconsole.log(this);  \/\/ undefined\n\n\/\/ \u800c\u4e0d\u662f\u5168\u5c40\u5bf9\u8c61\uff08window\uff09\n<\/code><\/pre>\n<h3>4. import \u7684\u63d0\u5347<\/h3>\n<pre><code class=\"language-javascript\">\/\/ import \u4f1a\u88ab\u81ea\u52a8\u63d0\u5347\u5230\u6587\u4ef6\u9876\u90e8\nfunc();  \/\/ \u53ef\u4ee5\u6b63\u5e38\u5de5\u4f5c\n\nimport { func } from '.\/utils.js';\n\n\/\/ \u4f46\u4e3a\u4e86\u53ef\u8bfb\u6027\uff0c\u5efa\u8bae\u628a import \u653e\u5728\u6587\u4ef6\u5f00\u5934\n<\/code><\/pre>\n<hr>\n<h2>\ud83c\udf93 \u5b9e\u6218\u5e94\u7528\u573a\u666f<\/h2>\n<h3>\u573a\u666f 1: \u5927\u578b Web \u5e94\u7528<\/h3>\n<pre><code class=\"language-javascript\">\/\/ \u5e94\u7528\u5165\u53e3\nimport { Router } from '.\/router.js';\nimport { Store } from '.\/store.js';\nimport { App } from '.\/App.js';\n\nconst app = new App({\n    router: new Router(),\n    store: new Store(),\n});\n\napp.mount('#app');\n<\/code><\/pre>\n<h3>\u573a\u666f 2: \u5de5\u5177\u5e93\u5f00\u53d1<\/h3>\n<pre><code class=\"language-javascript\">\/\/ my-utils\/index.js\nexport * from '.\/string.js';\nexport * from '.\/array.js';\nexport * from '.\/object.js';\nexport * from '.\/date.js';\n\n\/\/ \u7528\u6237\u4f7f\u7528\nimport { capitalize, formatDate, debounce } from 'my-utils';\n<\/code><\/pre>\n<h3>\u573a\u666f 3: \u7ec4\u4ef6\u5e93<\/h3>\n<pre><code class=\"language-javascript\">\/\/ my-ui\/index.js\nexport { Button } from '.\/Button.js';\nexport { Modal } from '.\/Modal.js';\nexport { Input } from '.\/Input.js';\nexport { default as Card } from '.\/Card.js';\n\n\/\/ \u7528\u6237\u4f7f\u7528\nimport { Button, Modal, Input, Card } from 'my-ui';\n<\/code><\/pre>\n<hr>\n<h2>\u270d\ufe0f \u7ec3\u4e60\u4efb\u52a1<\/h2>\n<h3>\u57fa\u7840\u7ec3\u4e60\uff08\u5fc5\u505a\uff09<\/h3>\n<ol>\n<li>\n<p><strong>\u5bfc\u51fa\u5bfc\u5165<\/strong>\uff1a<\/p>\n<ul>\n<li>[ ] \u521b\u5efa\u4e00\u4e2a\u5de5\u5177\u6a21\u5757\u5e76\u5bfc\u51fa\u51fd\u6570<\/li>\n<li>[ ] \u4f7f\u7528\u547d\u540d\u5bfc\u51fa\u548c\u9ed8\u8ba4\u5bfc\u51fa<\/li>\n<li>[ ] \u5728\u53e6\u4e00\u4e2a\u6a21\u5757\u4e2d\u5bfc\u5165\u4f7f\u7528<\/li>\n<\/ul>\n<\/li>\n<li>\n<p><strong>\u9879\u76ee\u7ed3\u6784<\/strong>\uff1a<\/p>\n<ul>\n<li>[ ] \u6309\u529f\u80fd\u7ec4\u7ec7\u6a21\u5757\u6587\u4ef6<\/li>\n<li>[ ] \u521b\u5efa index.js \u7edf\u4e00\u5bfc\u51fa<\/li>\n<li>[ ] \u914d\u7f6e package.json<\/li>\n<\/ul>\n<\/li>\n<li>\n<p><strong>\u52a8\u6001\u5bfc\u5165<\/strong>\uff1a<\/p>\n<ul>\n<li>[ ] \u5b9e\u73b0\u6309\u9700\u52a0\u8f7d\u6a21\u5757<\/li>\n<li>[ ] \u5904\u7406\u52a0\u8f7d\u9519\u8bef<\/li>\n<li>[ ] \u663e\u793a\u52a0\u8f7d\u72b6\u6001<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<h3>\u8fdb\u9636\u7ec3\u4e60\uff08\u63a8\u8350\uff09<\/h3>\n<ol>\n<li>\n<p><strong>\u6a21\u5757\u8bbe\u8ba1<\/strong>\uff1a<\/p>\n<ul>\n<li>\u8bbe\u8ba1\u4e00\u4e2a\u53ef\u590d\u7528\u7684\u8868\u5355\u9a8c\u8bc1\u6a21\u5757<\/li>\n<li>\u8bbe\u8ba1\u4e00\u4e2a HTTP \u8bf7\u6c42\u5c01\u88c5\u6a21\u5757<\/li>\n<li>\u8bbe\u8ba1\u4e00\u4e2a\u672c\u5730\u5b58\u50a8\u5c01\u88c5\u6a21\u5757<\/li>\n<\/ul>\n<\/li>\n<li>\n<p><strong>\u6784\u5efa\u5de5\u5177<\/strong>\uff1a<\/p>\n<ul>\n<li>\u4f7f\u7528 Vite \u6253\u5305\u9879\u76ee<\/li>\n<li>\u914d\u7f6e\u8def\u5f84\u522b\u540d\uff08@\/src\uff09<\/li>\n<li>\u4ee3\u7801\u5206\u5272\u548c\u61d2\u52a0\u8f7d<\/li>\n<\/ul>\n<\/li>\n<li>\n<p><strong>\u6700\u4f73\u5b9e\u8df5<\/strong>\uff1a<\/p>\n<ul>\n<li>\u547d\u540d\u89c4\u8303<\/li>\n<li>\u76ee\u5f55\u7ec4\u7ec7<\/li>\n<li>\u4f9d\u8d56\u7ba1\u7406<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<h3>\u5b9e\u6218\u6311\u6218\uff08\u9009\u505a\uff09<\/h3>\n<ol>\n<li>\n<p><strong>\u6784\u5efa\u7ec4\u4ef6\u5e93<\/strong>\uff1a<\/p>\n<ul>\n<li>\u5f00\u53d1\u4e00\u5957 UI \u7ec4\u4ef6<\/li>\n<li>\u53d1\u5e03\u5230 npm<\/li>\n<li>\u7f16\u5199\u6587\u6863\u548c\u793a\u4f8b<\/li>\n<\/ul>\n<\/li>\n<li>\n<p><strong>\u5fae\u524d\u7aef<\/strong>\uff1a<\/p>\n<ul>\n<li>\u6a21\u5757\u8054\u90a6<\/li>\n<li>\u8fd0\u884c\u65f6\u96c6\u6210<\/li>\n<li>\u72ec\u7acb\u90e8\u7f72<\/li>\n<\/ul>\n<\/li>\n<li>\n<p><strong>Monorepo<\/strong>\uff1a<\/p>\n<ul>\n<li>pnpm workspace<\/li>\n<li>Turborepo<\/li>\n<li>\u591a\u9879\u76ee\u7ba1\u7406<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<hr>\n<h2>\ud83d\udca1 \u5e38\u89c1\u95ee\u9898 FAQ<\/h2>\n<h3>Q1: ES6 \u6a21\u5757\u548c CommonJS \u53ef\u4ee5\u6df7\u7528\u5417\uff1f<\/h3>\n<p><strong>A<\/strong>:<\/p>\n<ul>\n<li>Node.js \u4e2d\u53ef\u4ee5\u6df7\u7528\uff0c\u4f46\u9700\u8981\u6b63\u786e\u5904\u7406<\/li>\n<li>\u4f7f\u7528 <code>.mjs<\/code> \u6269\u5c55\u540d\u8868\u793a ES6 \u6a21\u5757<\/li>\n<li>\u4f7f\u7528 <code>.cjs<\/code> \u6269\u5c55\u540d\u8868\u793a CommonJS<\/li>\n<\/ul>\n<h3>Q2: \u5982\u4f55\u5728\u6d4f\u89c8\u5668\u4e2d\u4f7f\u7528 ES6 \u6a21\u5757\uff1f<\/h3>\n<p><strong>A<\/strong>:<\/p>\n<pre><code class=\"language-html\">&lt;!-- \u65b9\u5f0f 1\uff1a\u4f7f\u7528 type=&quot;module&quot; --&gt;\n&lt;script type=&quot;module&quot; src=&quot;main.js&quot;&gt;&lt;\/script&gt;\n\n&lt;!-- \u65b9\u5f0f 2\uff1a\u5185\u8054\u6a21\u5757 --&gt;\n&lt;script type=&quot;module&quot;&gt;\n    import { func } from '.\/utils.js';\n    func();\n&lt;\/script&gt;\n<\/code><\/pre>\n<h3>Q3: \u6784\u5efa\u5de5\u5177\u662f\u5fc5\u987b\u7684\u5417\uff1f<\/h3>\n<p><strong>A<\/strong>:<\/p>\n<ul>\n<li>\u5f00\u53d1\u73af\u5883\u53ef\u4ee5\u4f7f\u7528\u539f\u751f ES6 \u6a21\u5757<\/li>\n<li>\u751f\u4ea7\u73af\u5883\u5efa\u8bae\u4f7f\u7528\u6784\u5efa\u5de5\u5177\uff08Vite\u3001Webpack\uff09<\/li>\n<li>\u6784\u5efa\u5de5\u5177\u63d0\u4f9b\u4f18\u5316\u3001\u517c\u5bb9\u6027\u3001\u6253\u5305\u7b49\u529f\u80fd<\/li>\n<\/ul>\n<h3>Q4: \u5982\u4f55\u5904\u7406\u6a21\u5757\u7248\u672c\uff1f<\/h3>\n<p><strong>A<\/strong>:<\/p>\n<pre><code class=\"language-json\">\/\/ package.json\n{\n  &quot;dependencies&quot;: {\n    &quot;lodash&quot;: &quot;^4.17.21&quot;,    \/\/ \u517c\u5bb9\u7248\u672c\n    &quot;axios&quot;: &quot;1.6.0&quot;,         \/\/ \u7cbe\u786e\u7248\u672c\n    &quot;react&quot;: &quot;~18.2.0&quot;        \/\/ \u8865\u4e01\u7248\u672c\n  }\n}\n<\/code><\/pre>\n<hr>\n<h2>\ud83d\udcda \u62d3\u5c55\u9605\u8bfb<\/h2>\n<h3>\u5b98\u65b9\u6587\u6863<\/h3>\n<ul>\n<li><a href=\"https:\/\/developer.mozilla.org\/en-US\/docs\/Web\/JavaScript\/Guide\/Modules\">MDN &#8211; JavaScript modules<\/a><\/li>\n<li><a href=\"https:\/\/nodejs.org\/api\/esm.html\">Node.js ES Modules<\/a><\/li>\n<\/ul>\n<h3>\u63a8\u8350\u8d44\u6e90<\/h3>\n<ol>\n<li><a href=\"https:\/\/exploringjs.com\/es6\/ch_modules.html\">JavaScript Modules<\/a><\/li>\n<li><a href=\"https:\/\/hacks.mozilla.org\/2018\/03\/es-modules-a-cartoon-deep-dive\/\">ES6 Modules in Depth<\/a><\/li>\n<\/ol>\n<h3>\u6784\u5efa\u5de5\u5177<\/h3>\n<ul>\n<li><a href=\"https:\/\/vitejs.dev\/\">Vite<\/a> &#8211; \u4e0b\u4e00\u4ee3\u524d\u7aef\u6784\u5efa\u5de5\u5177<\/li>\n<li><a href=\"https:\/\/webpack.js.org\/\">Webpack<\/a> &#8211; \u6a21\u5757\u6253\u5305\u5668<\/li>\n<li><a href=\"https:\/\/rollupjs.org\/\">Rollup<\/a> &#8211; JavaScript \u6a21\u5757\u6253\u5305\u5668<\/li>\n<\/ul>\n<hr>\n<h2>\ud83c\udf89 \u603b\u7ed3<\/h2>\n<p>\u4eca\u5929\u6211\u4eec\u6df1\u5165\u5b66\u4e60\u4e86 <strong>ES6 \u6a21\u5757\u5316\u5f00\u53d1<\/strong>\uff0c\u6db5\u76d6\u4e86\uff1a<\/p>\n<p>\u2705 <strong>\u6a21\u5757\u5316\u601d\u60f3<\/strong>\uff1a\u4e3a\u4ec0\u4e48\u9700\u8981\u6a21\u5757\u5316<br \/>\n\u2705 <strong>ES6 \u8bed\u6cd5<\/strong>\uff1aexport\u3001import\u3001default<br \/>\n\u2705 <strong>\u4ee3\u7801\u7ec4\u7ec7<\/strong>\uff1a\u6587\u4ef6\u7ed3\u6784\u3001\u547d\u540d\u89c4\u8303<br \/>\n\u2705 <strong>\u4f9d\u8d56\u7ba1\u7406<\/strong>\uff1anpm\u3001yarn\u3001package.json<br \/>\n\u2705 <strong>\u5b9e\u6218\u5e94\u7528<\/strong>\uff1a\u6784\u5efa\u53ef\u7ef4\u62a4\u7684\u5927\u578b\u9879\u76ee<\/p>\n<p><strong>\u6a21\u5757\u5316\u662f\u73b0\u4ee3 JavaScript \u5f00\u53d1\u7684\u57fa\u7840<\/strong>\uff0c\u638c\u63e1\u5b83\u80fd\u8ba9\u4f60\u5199\u51fa\u66f4\u6e05\u6670\u3001\u66f4\u6613\u7ef4\u62a4\u7684\u4ee3\u7801\u3002<\/p>\n<hr>\n<p><strong>\u4e0b\u4e00\u8282\u8bfe\u9884\u544a<\/strong>: Day 28 \u5c06\u5b66\u4e60 <strong>\u6784\u5efa\u5de5\u5177\u4e0e\u5de5\u7a0b\u5316<\/strong>\uff0c\u5b66\u4e60\u5982\u4f55\u4f7f\u7528 Vite \u6253\u5305\u9879\u76ee\uff01<\/p>\n<p>\ud83d\udcaa <strong>\u52a0\u6cb9\uff01\u575a\u6301\u5c31\u662f\u80dc\u5229\uff01<\/strong><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Day 27: \u6a21\u5757\u5316\u5f00\u53d1 \ud83d\udcc5 \u65e5\u671f: 2026\u5e7403\u670819\u65e5 \ud83c\udfaf \u5b66\u4e60\u76ee\u6807: \u638c\u63e1 ES6 \u6a21\u5757\u5316\uff0c\u5b66\u4f1a\u7ec4\u7ec7 &#8230; <a title=\"Day-27-\u6a21\u5757\u5316\u5f00\u53d1\" class=\"read-more\" href=\"https:\/\/www.resilence.cn\/?p=298\" aria-label=\"\u7ee7\u7eed\u9605\u8bfbDay-27-\u6a21\u5757\u5316\u5f00\u53d1\">\u9605\u8bfb\u66f4\u591a<\/a><\/p>\n","protected":false},"author":3,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[5],"tags":[],"class_list":["post-298","post","type-post","status-publish","format-standard","hentry","category-studycoding"],"_links":{"self":[{"href":"https:\/\/www.resilence.cn\/index.php?rest_route=\/wp\/v2\/posts\/298","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.resilence.cn\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.resilence.cn\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.resilence.cn\/index.php?rest_route=\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/www.resilence.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=298"}],"version-history":[{"count":1,"href":"https:\/\/www.resilence.cn\/index.php?rest_route=\/wp\/v2\/posts\/298\/revisions"}],"predecessor-version":[{"id":299,"href":"https:\/\/www.resilence.cn\/index.php?rest_route=\/wp\/v2\/posts\/298\/revisions\/299"}],"wp:attachment":[{"href":"https:\/\/www.resilence.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=298"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.resilence.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=298"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.resilence.cn\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=298"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}