您当前的位置: 首页 >  ui

js模块系统require和import区别与联系

彭世瑜 发布时间:2019-10-14 11:10:55 ,浏览量:2

模块加载原理
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区别?
关注
打赏
1688896170
查看更多评论

彭世瑜

暂无认证

  • 2浏览

    0关注

    2727博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文
立即登录/注册

微信扫码登录

0.5929s