粥里有勺糖

vuePress-theme-reco 粥里有勺糖    2018 - 2023
粥里有勺糖 粥里有勺糖

Choose mode

  • dark
  • auto
  • light
关于我
备战春秋
  • 心得总结
  • 校招考点汇总
  • 面经汇总
  • 复习自查
技术笔记
  • 技术教程
  • 模板工程
  • 源码学习
  • 技术概念
  • 个人作品
  • 学习笔记
计算机基础
  • 算法与数据结构
  • 操作系统
  • 计算机网络
  • 设计模式
  • 剑指offer
大前端
  • javascript
  • vue
  • html
  • css
  • 🌏浏览器专题
  • Web性能优化
  • regexp
  • node
面试
  • 问解
  • javascript
  • css
  • 手撕代码
  • 性能优化
  • 综合问题
  • 面经汇总
  • 小程序
手撕代码
  • 数据结构与算法
  • javascript
  • css
个人站点
  • GitHub (opens new window)
  • 博客园 (opens new window)
  • 掘金 (opens new window)
线上作品
  • 轻取(文件收集) (opens new window)
  • 个人图床 (opens new window)
  • 考勤小程序 (opens new window)
  • 时光恋人 (opens new window)
  • 在线简历生成 (opens new window)
留言板
Github (opens new window)
author-avatar

粥里有勺糖

285

文章

40

标签

关于我
备战春秋
  • 心得总结
  • 校招考点汇总
  • 面经汇总
  • 复习自查
技术笔记
  • 技术教程
  • 模板工程
  • 源码学习
  • 技术概念
  • 个人作品
  • 学习笔记
计算机基础
  • 算法与数据结构
  • 操作系统
  • 计算机网络
  • 设计模式
  • 剑指offer
大前端
  • javascript
  • vue
  • html
  • css
  • 🌏浏览器专题
  • Web性能优化
  • regexp
  • node
面试
  • 问解
  • javascript
  • css
  • 手撕代码
  • 性能优化
  • 综合问题
  • 面经汇总
  • 小程序
手撕代码
  • 数据结构与算法
  • javascript
  • css
个人站点
  • GitHub (opens new window)
  • 博客园 (opens new window)
  • 掘金 (opens new window)
线上作品
  • 轻取(文件收集) (opens new window)
  • 个人图床 (opens new window)
  • 考勤小程序 (opens new window)
  • 时光恋人 (opens new window)
  • 在线简历生成 (opens new window)
留言板
Github (opens new window)
  • JsInterview

    • js面试题
    • async 及 await 的特点,它们的优点和缺点分别是什么?await 原理是什么?
    • 数组哪些方法会改变自身
    • for-of与for-in的区别
    • == 和 === 有什么区别
    • ES6面试问题
    • 事件的触发过程是怎么样的?知道什么是事件代理嘛?
    • 将任意类型转为Boolean的方案
    • instanceof能正确判断对象的原因是什么
    • 如何判断数组
    • 如何判断变量类型是对象
    • 为什么要使用模块化?有哪几种方式可以实现模块化,各有什么特点?
    • null是对象吗
    • 为什么0.1+0.2!=0.3
    • 对象类型和原始类型的不同之处
    • 函数参数是对象会发生什么问题
    • window.onload与document.ready执行顺序
    • 原始类型有哪些
    • Promise 的特点是什么,分别有什么优缺点?什么是 Promise 链?Promise 构造函数执行和 then 函数执行有什么区别?
    • 如何正确判断 this?箭头函数的 this 是什么?
    • typeof能否正常判断类型
    • V8 下的垃圾回收机制是怎么样的?

为什么要使用模块化?有哪几种方式可以实现模块化,各有什么特点?

vuePress-theme-reco 粥里有勺糖    2018 - 2023

为什么要使用模块化?有哪几种方式可以实现模块化,各有什么特点?

粥里有勺糖 2020-04-14 面试javascript

# 为什么要使用模块化?有哪几种方式可以实现模块化,各有什么特点?

# 为什么要使用模块化?

好处

  • 解决命名冲突
  • 提高代码复用性
  • 提高项目的可维护性

# 有哪几种方式可以实现模块化,各有什么特点

  • IIFE(立即执行函数)
  • AMD
      define(['./a', './b'], function(a, b) {
        // 加载模块完毕可以使用
        a.do()
        b.do()
      })
    
    1
    2
    3
    4
    5
  • CMD
      define(function(require, exports, module) {
        // 加载模块
        // 可以把 require 写在函数体的任意地方实现延迟加载
        var a = require('./a')
        a.doSomething()
      })
    
    1
    2
    3
    4
    5
    6
  • CommonJS

CommonJS 最早是 Node 在使用,目前也仍然广泛使用,比如在 Webpack 中你就能见到它,当然目前在 Node 中的模块管理已经和 CommonJS 有一些区别了

  // a.js
  module.exports = {
      a: 1
  }
  // or 
  exports.a = 1

  // b.js
  var module = require('./a.js')
  module.a // -> log 1
1
2
3
4
5
6
7
8
9
10
  • ES Module

ES Module 是原生实现的模块化方案,与 CommonJS 有以下几个区别:

方案 导出 导入 语法 this
CommonJS 值拷贝/只能单个导出 动态导入(运行时加载)/同步导入 动态语法,可以写在判断中 当前模块
ES Module 值的引用/可以导出多个 编译时输出接口/异步导入 静态语法,只能写在最顶层 undefined

ES Module 会编译成 require/exports 来执行的

// 引入模块 API
import XXX from './a.js'
import { XXX } from './a.js'
// 导出模块 API
export function a() {}
export default function() {}
1
2
3
4
5
6
Edit this page (opens new window)
Last Updated: 2022/5/15 12:46:34