React 笔记 export 和 import 基本语法
一、ES6的模块化的基本规则或特点
- 每一个模块只加载一次, 每一个JS只执行一次, 如果下次再去加载同目录下同文件,直接从内存中读取。 一个模块就是一个单例,或者说就是一个对象;
- 每一个模块内声明的变量都是局部变量, 不会污染全局作用域模块内部的变量或者函数可以通过export导出
- 一个模块可以导入别的模块
二、几种import和export的基本语法
第一种导出
lib.js
let bar = "stringBar"; let foo = "stringFoo"; let sum = 1; let fn0 = function() { console.log("fn0"); } let fn1 = function() { console.log("fn1"); } let fnSum = function() { sum = sum + 1; return sum; } export{ bar, foo ,fn0, fn1, fnSum}
main.js
import {bar,foo, fn0, fn1, fnSum} from "./lib"; import {fnSum as fnSum1} from "./lib"; console.log(bar+"_"+foo); fn0(); //fn0 fn1(); //fn1 console.log(fnSum()); //2 console.log(fnSum()); //3 console.log(fnSum1()); //4
第二种导出
lib.js
let fn0 = function() { console.log("fn0"); }; let obj0 = {} export { fn0 as foo, obj0 as bar};
main.js
import {foo, bar} from "./lib"; foo(); //fn0 bar.name = '123'; console.log(bar);//Object {name: "123"}
第三种导出的方式
lib.js
export let foo = ()=> {console.log("fnFoo") ;return "foo"},bar = "stringBar";
main.js
import {foo, bar} from "./lib"; console.log(foo()); console.log(bar);
第四种导出的方式
lib.js
export default "string"
main.js
import defaultString from "./lib"; console.log(defaultString);
第五种导出方式
lib.js
let fn = () => "string"; export {fn as default};
main.js
import defaultFn from "./lib"; console.log(defaultFn());
第六种导出方式
other.js
export let foo = "stringFoo"; export let fnFoo = function() {console.log("fnFoo")};
lib.js
export * from "./other";
main.js
import {foo, fnFoo} from "./lib"; console.log(foo); console.log(fnFoo());
第七种导出方式
import * as obj from "./lib"; console.log(obj);
三、 ES6导入的模块都是属于引用
lib.js
export let counter = 3; export function incCounter() { counter++; } export function setCounter(value) { counter = value; }
main.js
import { counter, incCounter ,setCounter} from './lib'; // The imported value `counter` is live console.log(counter); // 3 incCounter(); console.log(counter); // 4 setCounter(0); console.log(counter); // 0
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)