webpack/examples/module/README.md

154 lines
3.4 KiB
Markdown
Raw Permalink Normal View History

# example.js
```javascript
import { increment as inc, value } from "./counter";
import { resetCounter, print } from "./methods";
print(value);
inc();
inc();
inc();
print(value);
resetCounter();
print(value);
2021-02-05 06:17:20 +08:00
export { inc, print };
```
# methods.js
```javascript
export { reset as resetCounter } from "./counter";
export const print = value => console.log(value);
```
# counter.js
```javascript
export let value = 0;
export function increment() {
value++;
}
export function decrement() {
value--;
}
export function reset() {
value = 0;
}
```
# dist/output.js
```javascript
2025-08-11 19:50:37 +08:00
/******/ // The require scope
/******/ var __webpack_require__ = {};
/******/
```
<details><summary><code>/* webpack runtime code */</code></summary>
``` js
/************************************************************************/
/******/ /* webpack/runtime/define property getters */
/******/ (() => {
/******/ // define getter functions for harmony exports
/******/ __webpack_require__.d = (exports, definition) => {
/******/ for(var key in definition) {
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
/******/ }
/******/ }
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/hasOwnProperty shorthand */
/******/ (() => {
/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
/******/ })();
/******/
/************************************************************************/
```
</details>
``` js
var __webpack_exports__ = {};
/*!********************************!*\
!*** ./example.js + 2 modules ***!
\********************************/
2020-05-21 05:26:51 +08:00
/*! namespace exports */
2021-02-05 06:17:20 +08:00
/*! export inc [provided] [used in main] [could be renamed] -> ./counter.js .increment */
/*! export print [provided] [used in main] [could be renamed] -> ./methods.js .print */
2025-08-11 19:50:37 +08:00
/*! runtime requirements: __webpack_exports__, __webpack_require__.d, __webpack_require__.* */
;// ./counter.js
let value = 0;
function increment() {
value++;
}
function decrement() {
value--;
}
function counter_reset() {
value = 0;
}
;// ./methods.js
const print = value => console.log(value);
;// ./example.js
print(value);
increment();
increment();
increment();
print(value);
counter_reset();
print(value);
2021-02-05 06:17:20 +08:00
export { increment as inc, print };
```
# dist/output.js (production)
```javascript
let o=0;function n(){o++}const c=o=>console.log(o);c(o),n(),n(),n(),c(o),o=0,c(o);export{n as inc,c as print};
```
# Info
## Unoptimized
```
2025-08-11 19:50:37 +08:00
asset output.js 1.68 KiB [emitted] [javascript module] (name: main)
chunk (runtime: main) output.js (main) 453 bytes (javascript) 396 bytes (runtime) [entry] [rendered]
2020-09-21 04:39:12 +08:00
> ./example.js main
2025-08-11 19:50:37 +08:00
runtime modules 396 bytes 2 modules
2021-02-05 06:17:20 +08:00
./example.js + 2 modules 453 bytes [built] [code generated]
[exports: inc, print]
[all exports used]
2020-09-21 04:39:12 +08:00
entry ./example.js main
2021-02-05 06:17:20 +08:00
used as library export
webpack X.X.X compiled successfully
```
## Production mode
```
asset output.js 110 bytes [emitted] [javascript module] [minimized] (name: main)
2025-08-11 19:50:37 +08:00
chunk (runtime: main) output.js (main) 453 bytes (javascript) 396 bytes (runtime) [entry] [rendered]
2020-09-21 04:39:12 +08:00
> ./example.js main
2025-08-11 19:50:37 +08:00
runtime modules 396 bytes 2 modules
2021-02-05 06:17:20 +08:00
./example.js + 2 modules 453 bytes [built] [code generated]
[exports: inc, print]
[all exports used]
2020-09-21 04:39:12 +08:00
entry ./example.js main
2021-02-05 06:17:20 +08:00
used as library export
webpack X.X.X compiled successfully
```