模块化

作者: 一土二月鸟 | 来源:发表于2020-05-30 10:36 被阅读0次

ES6模块化和CommonJS的区别

  • CommonJS主要用于服务器端node环境,不适用于浏览器端。
  • 因为require是一个运行时的同步操作,对于服务器来说是一个本地读取文件的操作,等待时间很短。但对于浏览器来说就成了网络文件请求,等待的时间会很长。因此CommonJS不适用于浏览器端。
正确
if(true){
  require('./a.js'); 
}
  • ES6模块化是尽可能的静态化,在编译阶段即知晓了依赖关系,在运行前会先把有依赖关系的文件全部下载好以后才开始执行。
  • ES6运行过程中,改变了模块中的值,会同步到import的文件中。
报错
if(true){
  import a from './a.js'; 
}
  • ES6 module导出的是一个接口,CommonJS导出的是一个js对象
错误:由于不是对象不能使用es6的解构语法
import { a: b } from './a.js'; 
正确:
var { a: b } = require(./a.js);

ES6模块化

ES6模块化用法

  • 浏览器支持ES6 module,不支持CommonJS
  • 使用<script type="module">
  • 将网页部署到服务器,本地无法直接运行
  • es6 module为'use strict'模式

export

  • 导出的相当于是一个接口,类似一个对象,必须有key值的存在
  • 但使用export default不需要有key值,default关键字就相当于是key值
export var a = 1; 
等价于
var a = 1;
export { a }

错误用法:
export 1;  // 相当于没有key值
var a = 1;
export a;
export [];

正确用法:
export {};
export { a: 1 };
export default 1;

export {} 的用法

export { a: 1, b: 2 } // test.js
// 相当于export a 

import { a } from 'test.js'

export {} 和 export default {} 的区别

??export {} 相当于是一个接口,把每个单独的export进行了汇总 import时需要使用 {} 进行导入
export default {} 导出的是一个对象,import时不可以直接使用{} 进行解构 import不支持解构

相关文章

  • ES6学习笔记 II

    模块化 注意:模块化需要放到服务器环境使用模块化: 定义模块化如下 export export const a =...

  • 前端开发——模块化(css模块化开发)

    掌握模块化开发的思想是我们进行模块化开发的基础。他有以下几部分组成: 模块化开发的优势 css模块化 css模块化...

  • Node.js模块化学习

    模块化的基本概念Node.js 中模块化npm与包模块的加载机制 模块化的基本概念 什么是模块化 模块化是指解决一...

  • webpack基础笔记

    webpack基础 1.前端工程化 实际的前端开发: 模块化:(js的模块化,css的模块化,资源的模块化) 组件...

  • 模块化开发

    js模块化开发vue模块化开发

  • Vue前端工程化

    1.模块化的分类 A.浏览器端的模块化 B.服务器端的模块化 C.ES6模块化 小结:推荐使用ES6模块化,因为A...

  • 前端工程化

    1.模块化的分类 A.浏览器端的模块化 B.服务器端的模块化 C.ES6模块化 小结:推荐使用ES6模块化,因为A...

  • vue5

    es6新内容 class 解构赋值 扩展对象 模块化 什么是模块化 模块的作用 怎么实现模块化 模块化的标准 Co...

  • Vue基础教程之-组件核心概念(四)

    一、模块化 1.1 为什么需要模块化 没有模块化的世界:全局变量污染、难以管理的依赖。常见的模块化标准:Commo...

  • vue项目基建

    路由模块化 , 高频全局组件模块化 权限

网友评论

      本文标题:模块化

      本文链接:https://www.haomeiwen.com/subject/awlczhtx.html