子產品加載原理
var module = {
exports: {}
};
(function(module, exports) {
exports.multiply = function (n) {
return n * 1000
};
}(module, module.exports))
var f = module.exports.multiply;
f(5) // 5000
require和import
1、差別
require / exports 是 CommonJS(在Node中實作)
import / export 是 ES2015 的子產品
require是動态加載
import是靜态加載
2、聯系
import -> babel打包 -> require
CommonJS 格式轉換的工具:
http://browserify.org/3、示例
require
// 引入
const fs = require('fs')
// 導出
exports.fs = fs
module.exports = fs
import
// 引入
import fs from 'fs'
import {readFile} from 'fs'
// 導出
export default fs
export const fs
export function readFile
export {readFile, read}
exports 和 module.exports
exports 隻能使用.文法向外暴露内部變量
例 exports.xxx=xxx
module.exports既可以通過點文法,也可以直接指派一個對象
例 module.exports.xxx=xxx
參考 深入了解CommonJS!
其他文章