aboutsummaryrefslogtreecommitdiff
path: root/files/zh-tw/web/javascript/reference/statements/import/index.html
blob: 028366c36dcd1936afd014c76325c3bef9eb4f1e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
---
title: import
slug: Web/JavaScript/Reference/Statements/import
translation_of: Web/JavaScript/Reference/Statements/import
---
<div>{{jsSidebar("Statements")}}</div>

<p><strong>import</strong> 宣告用於引入由另一個模塊所導出的綁定。被引入的模塊,無論是否宣告{{jsxref("Strict_mode","strict mode","嚴謹模式")}},都會處於該模式。<code>import</code> 宣告無法用於嵌入式腳本(embedded scripts)。</p>

<p>There is also a function-like dynamic <code><strong>import()</strong></code>, which does not require scripts of <code>type="module"</code>.</p>

<p>Dynamic import is useful in situations where you wish to load a module conditionally, or on demand. The static form is preferable for loading initial dependencies, and can benefit more readily from static analysis tools and <a href="/en-US/docs/Glossary/Tree_shaking">tree shaking</a>.</p>

<h2 id="語法">語法</h2>

<pre class="syntaxbox">import <em>defaultExport</em> from "<em>module-name</em>";
import * as <em>name</em> from "<em>module-name</em>";
import { <em>export </em>} from "<em>module-name</em>";
import { <em>export</em> as <em>alias </em>} from "<em>module-name</em>";
import { <em>export1 , export2</em> } from "<em>module-name</em>";
import { <em>export1 , export2</em> as <em>alias2</em> , <em>[...]</em> } from "<em>module-name</em>";
import <em>defaultExport</em>, { <em>export</em> [ , <em>[...]</em> ] } from "<em>module-name</em>";
import <em>defaultExport</em>, * as <em>name</em> from "<em>module-name</em>";
import "<em>module-name</em>";</pre>

<dl>
 <dt><code>defaultExport</code></dt>
 <dd>從模塊要參照過去的預設導出名。</dd>
 <dt><code>module-name</code></dt>
 <dd>要導入的模塊名。通常包含 <code>.js </code> 模塊文件的相對或絕對路徑名。請確認你的開發環境,某些bundler 會允許或要求你加入副檔名。只允許使用單引號和雙引號字符串。</dd>
 <dt><code>name</code></dt>
 <dd>參照導入時,會用做 namespace 種類的模塊名。</dd>
 <dt><code>export, exportN</code></dt>
 <dd>導出要被引入時,要用的名號。</dd>
 <dt><code>alias, aliasN</code></dt>
 <dd>別名,重新命名被import進來的js稱呼。</dd>
</dl>

<h2 id="敘述">敘述</h2>

<p><code>name</code> 參數能將模塊物件(module object)名用於 namespace 種類,以便各導出能參照之。<code>export</code> 參數會在引用 <code>import * as name</code> 語法時,指定 individual named export。以下示例將展示語法的簡例。</p>

<h3 id="引入整個模塊的內容">引入整個模塊的內容</h3>

<p>本例在當前作用域插入了 <code>myModule</code> 變數,並把所有來自 <code>/modules/my-module.js</code> 檔案的模塊導出。</p>

<pre class="brush: js">import * as <em>myModule</em> from '/modules/my-module.js';
</pre>

<p>這裡會用到指定的模塊名(在此為 myModule)訪問導出來的命名空間。例如說引入模塊有 <code>doAllTheAmazingThings()</code> 的話,就可以這麼寫:</p>

<pre class="brush: js">myModule.doAllTheAmazingThings();</pre>

<h3 id="從模塊引入單一導出">從模塊引入單一導出</h3>

<p>給定由 <code>my-module</code> 導出的模塊,稱作 <code>myExport</code> 物件與數值,無論是顯性(因為整個模塊被導出了)與隱性(使用 {{jsxref("Statements/export", "export")}} 宣告),這裡就在當前的作用域插入 <code>myExport</code></p>

<pre class="brush: js">import {myExport} from '/modules/my-module.js';</pre>

<h3 id="從模塊引入數個導出">從模塊引入數個導出</h3>

<p>例在當前作用域插入了 <code>foo</code><code>bar</code></p>

<pre class="brush: js">import {foo, bar} from '/modules/my-module.js';</pre>

<h3 id="使用便利的_alias_引入或導出">使用便利的 alias 引入或導出</h3>

<p>在引入時,可以重新命名導出的模塊。例如說,這裡就就在目前作用域插入 <code>shortName</code> 變數。</p>

<pre class="brush: js">import {reallyReallyLongModuleExportName as shortName}
  from '/modules/my-module.js';</pre>

<h3 id="引入時重命名數個導出">引入時重命名數個導出</h3>

<p>使用別名(aliases)以便引入或導出模塊</p>

<pre class="brush: js">import {
  reallyReallyLongModuleExportName as shortName,
  anotherLongModuleName as short
} from '/modules/my-module.js';</pre>

<h3 id="僅作為副作用引入模塊">僅作為副作用引入模塊</h3>

<p>僅作為副作用(side effect)引入整個模塊,而不直接引入任何東西。這樣會在不引入實際數值的情況下,執行整個模塊的程式。</p>

<pre class="brush: js">import '/modules/my-module.js';
</pre>

<h3 id="引入預設">引入預設</h3>

<p>你可以引入預設好的 {{jsxref("Statements/export", "export")}},無論他屬於物件、函式、還是類別。<code>import</code> 宣告可以接著引入該預設。</p>

<p>最簡單的預設引入:</p>

<pre class="brush: js">import myDefault from '/modules/my-module.js';</pre>

<p>It is also possible to use the default syntax with the ones seen above (namespace imports or named imports). In such cases, the default import will have to be declared first. For instance:</p>

<pre class="brush: js">import myDefault, * as myModule from '/modules/my-module.js';
// myModule used as a namespace</pre>

<p>或是:</p>

<pre class="brush: js">import myDefault, {foo, bar} from '/modules/my-module.js';
// specific, named imports
</pre>

<h3 id="動態引入">動態引入</h3>

<p><code>import</code> 關鍵字也能透過函式呼叫引入之。在這種情況下,該函式回傳 promise。</p>

<pre class="brush: js">import('/modules/my-module.js')
  .then((module) =&gt; {
    // 在模塊內作點事情
  });
</pre>

<p>這方法也支援關鍵字 await。</p>

<pre class="brush: js">let module = await import('/modules/my-module.js');</pre>

<h2 id="示例">示例</h2>

<p>引用次要模塊以協助程式執行 AJAX JSON 請求。</p>

<h3 id="模塊:file.js">模塊:file.js</h3>

<pre class="brush: js">function getJSON(url, callback) {
  let xhr = new XMLHttpRequest();
  xhr.onload = function () {
    callback(this.responseText)
  };
  xhr.open('GET', url, true);
  xhr.send();
}

export function getUsefulContents(url, callback) {
  getJSON(url, data =&gt; callback(JSON.parse(data)));
}</pre>

<h3 id="主要程式:main.js">主要程式:main.js</h3>

<pre class="brush: js">import { getUsefulContents } from '/modules/file.js';

getUsefulContents('http://www.example.com',
    data =&gt; { doSomethingUseful(data); });</pre>

<h3 id="動態引入_2">動態引入</h3>

<p>This example shows how to load functionality on to a page based on a user action, in this case a button click, and then call a function within that module. This is not the only way to implement this functionality. The <code>import()</code> function also supports <code>await</code>.</p>

<pre class="brush: js">const main = document.querySelector("main");
for (const link of document.querySelectorAll("nav &gt; a")) {
  link.addEventListener("click", e =&gt; {
    e.preventDefault();

    import('/modules/my-module.js')
      .then(module =&gt; {
        module.loadPageInto(main);
      })
      .catch(err =&gt; {
        main.textContent = err.message;
      });
  });
}</pre>

<h2 id="規範">規範</h2>

<table class="standard-table">
 <tbody>
  <tr>
   <th scope="col">規範</th>
   <th scope="col">狀態</th>
   <th scope="col">註解</th>
  </tr>
  <tr>
   <td>{{SpecName('ES2015', '#sec-imports', 'Imports')}}</td>
   <td>{{Spec2('ES2015')}}</td>
   <td>Initial definition.</td>
  </tr>
  <tr>
   <td>{{SpecName('ESDraft', '#sec-imports', 'Imports')}}</td>
   <td>{{Spec2('ESDraft')}}</td>
   <td> </td>
  </tr>
 </tbody>
</table>

<h2 id="瀏覽器相容性">瀏覽器相容性</h2>



<p>{{Compat("javascript.statements.import")}}</p>

<h2 id="參見">參見</h2>

<ul>
 <li>{{jsxref("Statements/export", "export")}}</li>
 <li><a href="https://blogs.windows.com/msedgedev/2016/05/17/es6-modules-and-beyond/">Previewing ES6 Modules and more from ES2015, ES2016 and beyond</a></li>
 <li><a href="https://hacks.mozilla.org/2015/08/es6-in-depth-modules/">ES6 in Depth: Modules</a>, Hacks blog post by Jason Orendorff</li>
 <li><a href="https://hacks.mozilla.org/2018/03/es-modules-a-cartoon-deep-dive/">ES modules: A cartoon deep-dive</a>, Hacks blog post by Lin Clark</li>
 <li><a class="external" href="http://exploringjs.com/es6/ch_modules.html">Axel Rauschmayer's book: "Exploring JS: Modules"</a></li>
</ul>