天天看點

js子產品系統require和import差別與聯系

子產品加載原理

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!

其他文章

  1. require,import差別?

繼續閱讀