首页 > 其他分享 >ES6——模块化

ES6——模块化

时间:2022-12-14 17:36:02浏览次数:51  
标签:ES6 babel 模块化 js index3 import

 模块化

  模块化是指将一个大的程序文件,拆分成许多小的文件,然后将小文件组合起来。

一、浏览器使用ES6模块化方式一

  使用script标签,将type属性设置为module,然后在script中书写代码。

1 <script type="module">
2     import * as app from "./app.js";
3 </script>

1.1 模块化的好处

  • 防止命名冲突

  • 代码复用

  • 高维护性

1.2 ES6模块化语法

  模块化功能只要有两个命令构成:export和import。

  • export命令用于规定模块的对外接口

  • import命令用于输入其他模块提供的功能

1.3 ES6暴露模块数据

1.3.1 分别暴露

  index1.js

1 //暴露数据:export
2 export let person = '张三';
3 
4 export function sayHi(){
5     console.log("你好我是张三");
6 };

  index.html

1 <body>
2     <script type="module">
3         //引入index1模块
4         import * as index1 from "./index1.js";
5         console.log(index1);
6     </script>
7 </body>

  注:这样的写法在本地会出现跨域问题,通过IP去访问,相当于是通过本地的服务器去访问就不会了,不要通过file协议去访问。也可使用Live Server之类的小型服务器来打开就可以避免以上问题。

1.3.2 统一暴露

  index2.js

1 let person = '张三';
2 
3 function sing(){
4     console.log("我会唱歌");
5 };
6 //统一暴露
7 export {person, sing};//花括号里边是要暴露的数据

  index.html

1 <body>
2     <script type="module">
3         //引入index2模块
4         import * as index2 from "./index2.js";
5         console.log(index2);
6     </script>
7 </body>

1.3.3 默认暴露

  index3.js

1 //可以暴露任意类型,对象居多
2 export default {
3     person: '张三',
4     coding: function (){
5         console.log("我在敲代码");
6     }
7 }

  index.html

1 <body>
2     <script type="module">
3         //引入index3模块
4         import * as index3 from "./index3.js";
5         console.log(index3);
6     </script>
7 </body>

  对于这样一个结构,我们如果想要使用里边的属性或者方法就需要再多加一个default。

1 <body>
2     <script type="module">
3         //引入index3模块
4         import * as index3 from "./index3.js";
5         index3.default.coding();
6     </script>
7 </body>

1.4 ES6引入模块数据语法

1.4.1 通用导入方式

import * as 变量名 from "模块路径";

1.4.2 解构赋值形式

  如果有相同的数据名,我们可以给其中一个添加一个别名。

1 import {要暴露的数据名, 要暴露的数据名} from "模块路径";
2 //例
3 //分别暴露
4 import {person,sayHi} from "./index1.js";
5 //起别名(统一暴露),因为和上边分别暴露的person重名了需要起别名
6 import {person as ren, sing} from "./index.js";
7 console.log(ren,sing);

  解构赋值对于默认暴露,不能直接使用default必须给它起一个别名。

1 import {default as 别名} from "模块路径";
2 //例(固定写法)
3 import {default as index3} from "./index3.js";
4 console.log(index3);

1.4.3 简便形式

  注意:简便形式只能针对默认暴露。

1 import 变量名 from "模块路径";
2 //例
3 import index3 from "./index3.js";

二、浏览器使用ES6模块化方式二

  使用一个script中的src属性引一个入口文件,然后设置type属性为module。

1 <script src="./app.js" type="module"></script>

三、babel对ES6模块化代码转换

  前边提到的两种使用模块化的方式都存在兼容性的问题,并且ES6模块化还不能直接对npm安装的一些模块进行导入。因此我们在项目当中不会这么引入,而是使用babel做一个转化。

  babel是一个JavaScript编译器,它能够将比较新的ES6语法转换成浏览器能够识别的ES5语法。

3.1 安装工具

  • babel-cli:babel的命令行工具

  • babel-preset-env:预设包,能够将最新的ECMAscript特性进行转换

  • browserify(webpack):一个打包工具

  1.初始化
npm init --yes
  2.安装

  -D:开发依赖

npm i babel-cli babel-preset-env browserify -D
  3.对代码进行转化(局部安装)

  第一个参数是原文件的目录

  -d:将转换完的结果存在哪

  --presets=babel-preset-env:传的参数,可以直接建一个文件

npx babel ES6/23-ES6模块化/js -d dist/js --presets=babel-preset-env

  全局安装可以直接使用babel

  4.打包

  第一个参数是原文件的目录

  -o:输出

npx browserify dist/js/app.js -o dist/bundle.js
  5.在页面上引用
1 <script src="../dist/bundle.js"></script>

四、ES6模块化引入NPM包

  需求:使用jQuery对文件进行背景色修改。

  要想使用npm

  1.安装所需包

npm i jquery

  2.import 变量名 from "要导入的模块名";

import $ from "jquery";

标签:ES6,babel,模块化,js,index3,import
From: https://www.cnblogs.com/chuzhi/p/16982722.html

相关文章

  • 《ES6标准入门》读书笔记
         嗯,之前之做项目大概了解一些,之后看Vue实战里讲一些,简历里写了这个,所以决定系统学习,第一次接触大佬阮一峰是讲Flex布局的一篇博文,感觉很好,居然把书开源,嗯,......
  • JS执行机制及ES6
    一、JS执行机制JS语言有个特点是单线程,即同一时间只能做一件事。单线程就意味着,所有的任务需要排队,前一个任务结束,才会执行后一个任务,可能造成页面渲染不连贯。为了......
  • ES6笔记 - Promise对象
    Promise对象目录Promise对象1.Promise简介2.Promise的使用2.1创建Promise对象2.2Promise的执行时间2.3简写形式3.then方法4.catch方法5.all方法和race方法6.reso......
  • es6新特性------学好类(class)这一篇就够了
    OverridetheentrypointofanimageIntroducedinGitLabandGitLabRunner9.4.Readmoreaboutthe extendedconfigurationoptions.Beforeexplainingtheav......
  • JavaScript入门⑩-ES6归纳总结
    JavaScript入门系列目录JavaScript入门①-基础知识筑基JavaScript入门②-函数(1)基础{浅出}JavaScript入门③-函数(2)原理{深入}执行上下文JavaScript入门④-万物皆......
  • js模块化
    OverridetheentrypointofanimageIntroducedinGitLabandGitLabRunner9.4.Readmoreaboutthe extendedconfigurationoptions.Beforeexplainingtheav......
  • es6模块再理解
    1//test.mjs2exportdefaultfunction(){3console.log('foo');4}56exportvara1="aaaaaaaaaa"78exportvarb1="bbbbbbbbbb"1/......
  • ES6——Promise
    一、ES6——Promise1.1Promise介绍与基本使用Promise是ES6引入的异步编程的新解决方案。语法上promise是一个构造函数,用来封装异步操作并获取其成功或失败的结果。......
  • ES6笔记 - proxy简介
    Proxy目录Proxy1.Proxy简介2.注意事项3.Proxy支持的所有拦截操作4.使用示例1.Proxy简介Proxy可以理解为在目标对象前架设一个"拦截层",外界对该对象的访问都必须......
  • ES6笔记 - 原型对象扩展
    原型对象扩展目录原型对象扩展1.__proto__属性2.Object.setPrototypeOf()3.Object.getPrototypeOf()1.__proto__属性__proto__属性用来读取或设置当前对象的protot......