es6—module模块

2023-05-16

文章目录

  • 0.模块化相关
    • 0.babel配置
  • 1.使用原因
  • 2.基本语法
      • 1.1 导出 export
      • 1.2 导入import m1,{s1,s2} from ' '
      • 1.3注意:module静态导入,
    • 2.1 整体加载
    • 3.1 默认输出,导入时不加 { }
      • 正常输出,导入时加{ }
      • 4.1 复合写法

0.模块化相关

1.浏览器的JS模块化 :AMD,CMD
2.服务器端:CommonJS,浏览器默认支持
3.大一统模块化规范 - ES6模块化——module
4. node默认支持commonjs,但对es6支持有限,需要通过 babel【语法转化工具】 在node中体验es6模块化,

0.babel配置

在这里插入图片描述
之后允许使用高级es6语法

1.使用原因

  1. 大程序拆分为相互依赖小文件,再简单方法拼接
  2. 好处:1>避免变量污染,命名冲突 2>提供代码的复用率、维护性 3>依赖关系管理
    在这里插入图片描述
    在这里插入图片描述

2.基本语法

1.1 导出 export

// 导出暴露变量
let name = "GYP";
let age = 20;
export { name, age }

// 暴露对象
let obj = {
    name: '郭研苹',
    age: 20
}
export { obj };

// 3.1 导出暴露函数
export function addFn(a, b) {
    console.log(a + b);
}

function fn1() {
    console.log(fn1);
}

function fn2() {
    console.log(fn2);
}
export { fn1 as tempfn1, fn2 as tempfn2 }

1.2 导入import m1,{s1,s2} from ’ ’

m1-默认导入,{s1}按需导入

//0.不必导出,直接导入
//m2.js:
for(let i = 0;i < 3;i++) {
	log(i)l
}
//index.js
import './m2.js'//0,1,2
// 1.接受导入变量,不可修改
import { name, age } from './export.js'
console.log(`前辈您好,我叫${name},今年${age}`);
// GYP,20

// 2.导入对象属性,可以修改
import { obj } from './export.js'
obj.age = 18;
console.log(obj);
console.log(`你好,我叫${obj.name},今年${obj.age}`);
//郭研苹 18

// 3.导入函数 函数名 as 别名
add(20, 30); //存在变量提升
import { addFn as add } from './export.js'
//50

// 3.2 多个函数导入
import { tempfn1, tempfn2 } from './export.js';
tempfn1();
tempfn2();
//打印以上函数

注意

  1. import 导入前需要 export 导出在终端进行npx babel -node
  2. 每个js中仅允许唯一一次默认导出 export default,但可以有多次 按需导出
  3. 未导出就导入,终端出现 undefined

1.3注意:module静态导入,

不能使用表达式和变量内些运行时才能看到结果导入
错误示范;

// 错误示范1
let path = './export.js'
import tempfn1 from path;
//错误示范2
if(l == 1) {
	import {addFn1 as test} from './export.js'
}

2.1 整体加载

export.js

function fn1(args) {
    return args;
}

function fn2(...args) {
    return (args) * 2;
}
export { fn1, fn2 }

import.js

//全部导入对象中
import * as obj from './export.js';
console.log(obj);
console.log('fn1', obj.fn1(123)); // fn1 123
console.log('fn2', obj.fn2(6)); // fn2 12

3.1 默认输出,导入时不加 { }

export default function() {}

export default class Person {
    constructor(name) {
        this.name = name;
    }
}

import

import Person from './export.js';
let p = new Person('gyp');
console.log(p);
// Person iname: 'gyp '3

正常输出,导入时加{ }

4.1 复合写法

public.js

export let number = 10;

export.js

export {number} from 'public.js'

import.js

import {number} from './export.js'
log(number)//10

在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

es6—module模块 的相关文章

随机推荐

  • 【面试宝典】软件测试工程师2021烫手精华版(第一章测试理论篇)

    前言 xff1a 翻了很多论坛博客关于面试的文章 xff0c 很多都是不完整的 xff0c 还都是比较常见规规矩矩的 xff0c 那大家刷过的基本都不拿出来了 xff0c 都是一些大家平时见得不多 xff0c 但是面试官很看中的一些题 第一
  • uniapp package.json和mainfest.json,如何区分环境变量

    uniapp在hbuilder中 xff0c 导航的运行就是development xff0c 发行就是production package json 如果是往服务器上发布版本 xff0c 则是打包成zip在服务器上解压 xff0c 但注意
  • VSCode扩展时出错XHRfaile问题解决

    问题 VScode扩展插件链接网络失败XHR faile错误 解决办法 1 第一步 xff1a 文件 gt 首选项 gt 设置 gt 如下图 xff1a 2 第二步 xff1a 用户 gt 应用程序 gt 代理服务器 gt 如下图操作 xf
  • HDFS的启动流程和HA

    HDFS的启动流程 当 NameNode 启动时HDFS首先将Fsimage读入内存对元数据进行恢复 xff0c 然后再读edits文件中的更新操作在恢复后的元数据上进行执行 xff0c 使得此时的NameNode中保存的是停止前的最新状态
  • 『XXG笔记』Github pages 自定义域名

    x1f44b 本文章为我 XXG 原创 xff0c 由于个人能力有限 xff0c 此笔记可能会错漏 过时 或需要补充 x1f4d6 笔记文章由于多平台发布 xff0c 为了修改方便 xff0c 可以参观我的博客 xff1a https xx
  • 第十八篇,Simulink with Git

    一 综述 本篇以MATLAB R2021b为基础讲解如何对Simulink模型做Git管理 xff0c mdl与slx均可 Git并非只能对手写代码做版本管理 xff0c 它的应用十分广泛 xff0c 囊括了各种使用编程语言编写的代码 脚本
  • 第十九篇,解析法求解五阶多项式

    x0为初始约束 xff0c 时间为0 xff1b x1为结束约束 xff0c 时间为t coef 为求解结果 xff0c 定义x 61 at 5 43 bt 4 43 ct 3 43 dt 2 43 et 43 f xff0c 则coef
  • 第二十篇,Simulink使用痛点记录

    在工作实践中发现了MATLAB amp amp Simulink一些虽不致项目失败但的确很不方便的点 xff0c 记录下来以备持续研究 xff0c 并做分享 xff1b 都是个人认为比较基础的能力或者容易做到的特性 xff0c MATLAB
  • 第七篇(下),MPC工程化总结

    目录 一 引言 二 MPC的理解与实现 2 1 模型设计与实现 2 2 MPC工程实现步骤 三 参考资料 3 1 基础理论 3 2 Refer to Apollo 3 3 其它实例参考 3 4 MATLAB中的MPC 四 demo代码 一
  • es6 -- 解构赋值

    文章目录 1 数组的解构赋值 xff0c 按次序排列 xff0c 位置决定2 对象的解构赋值 xff0c 没有次序 xff0c 变量与属性同名即可取值 默认undefined3 字符串的解构赋值4 数值和布尔值的结构赋值5 函数结构赋值 被
  • 第二十一篇,常用Git操作记录

    一 拉取远程分支 拉取远程名叫dev的分支 git fetch origin dev 执行后本地git branch并不能看到dev git checkout dev 可以看到dev了 xff0c 在dev上开发 二 本地新建分支推送到远程
  • 第二十二篇,C++面经之问答(一)

    目录 一 传引用有没有拷贝 二 引用和指针的区别 三 构造 析构函数中可不可以调用虚函数 四 怎样区分继承和组合 五 多态的实现原理 虚表虚指针 六 用过哪些设计模式 6 1状态模式 6 2享元模式 6 3单例模式 6 4工厂模式 6 5观
  • 第二十三篇,C++面经之问答(二)

    目录 一 lambda表达式的应用场景 二 lambda表达式传引用有什么坑 三 C 43 43 为什么引入线程的语言级支持 四 如何优雅地关闭一个阻塞中的线程 五 线程不做join 或detach 会有什么问题 六 多线程同步 xff0c
  • 第二十四篇,C++面经之问答(三)

    目录 一 TCP UDP的区别 应用场景 二 UDP里client server使用的过程 三 TCP端口复用问题 四 TCP三次握手 五 TCP四次挥手 六 Qt信号槽的连接方式 七 一个信号连接多个槽时 xff0c 槽函数的调用顺序 八
  • 第二十五篇,C++面经之问答(四)

    目录 一 std string是深拷贝还是浅拷贝 xff0c 深拷贝与浅拷贝的区别 二 string vector等容器中 xff0c size和capacity的区别 三 vector和list的区别 map和set的区别 四 STL中的
  • 第二十六篇,C++面经之问答(五)

    一 new delete和malloc free的区别 new delete是C 43 43 的关键字 操作符 xff0c malloc free是C的函数 xff0c 需引入 lt stdlib h gt new会调用构造函数会初始化并返
  • 第二十七篇,C++面经之手写代码(一)

    前几篇整理 记录了面试遇到的问答题目 xff0c 接下来再开几篇 xff0c 写一写手写代码环节的题目 xff0c 尽量加上注释或者讲解 xff0c 并把代码写完整 xff0c 达到复制粘贴后可立即编译执行的程度 语言还是C 43 43 x
  • 第二十八篇,C++面经之手写代码(二)

    第二篇以几个经典排序算法开始吧 一 快速排序 span class token keyword void span span class token function QuickSort span span class token punc
  • 第三十篇,C++面经之手写代码(四)

    一 删除数组指定元素 span class token keyword void span span class token function func span span class token punctuation span span
  • es6—module模块

    文章目录 0 模块化相关0 babel配置 1 使用原因2 基本语法1 1 导出 export1 2 导入import m1 s1 s2 from 39 39 1 3注意 xff1a module静态导入 xff0c 2 1 整体加载3 1