当前位置:首页 > 编程技术 > 正文内容

JS ES6 模块化开发入门

yc8881年前 (2022-12-29)编程技术197

JS ES6  模块化开发入门

1. 模块的基本使用


定义一个js模块

  1. let title = '辰风沐阳'
  2. let url = 'https://www.itqaq.com/index/art/279.html'
  3. function show() {
  4. console.log('this is show method')
  5. }
  6. export { title, url, show }

type="module" 表示使用模块化, ./module/1.js 中的 ./ 不能省略

  1. <script type="module">
  2. import { title, url, show } from "./module/1.js"
  3. console.log(title)
  4. console.log(url)
  5. show()
  6. </script>

2. 模块延迟解析


因为模块之间会有依赖关系,所以系统在处理模块时会加载全部模块后才会执行模块

所以模块化js代码放在 button 标签之前,也能找到 button 标签

  1. <script type="module">
  2. console.log(document.querySelector('button'))
  3. </script>
  4. <button>测试</button>

3. 作用域在模块中的体现


模块有自己的独立作用域,在模块中定义的变量只能在模块内部使用

在模块内部可以使用全局作用域的变量,但在外部则不能使用模块内部的变量,只有使用 export 导出才能在外部使用

4. 模块的预解析


无论模块加载多少次,只会在第一次时产生执行

5. 模块的具名导出和导入


具名导出: 顾名思义,就是导出具有名称的成员

  1. let site = 'wwww.itqaq.com'
  2. function show() {
  3. console.log('this is show ')
  4. }
  5. export { site, show }

6. 批量导入 * as name


  1. // 导出的内容
  2. export { site, url }
  3. // 导入
  4. import * as api from './modules/http.js'
  5. console.log(api.url)
  6. console.log(api.site)

7. 导出、导入 别名的使用


  1. import { site as name } from './modules/user.js'

8. 模块的默认导出


export 导出数据时使用 default 代表时默认导出,那么在导入模块时接收的名称可以任意定义

  1. export default function show() {
  2. console.log('this is show ')
  3. }
  4. import api from './modules/show.js'

默认导出本质上是给导出的成员设置了别名 default,这也是默认导出只能写一个的原因

  1. export { show as default }

接收默认导出的成员,下面两种写法都可以

  1. import user from './modules/show.js';
  2. import { default as user } from './modules/show.js';

具名导出和默认导出的混合使用及其导入

  1. // 导出
  2. export const domain = 'https://www.itqaq.com';
  3. export default function request() {
  4. return new Promise((resolve, reject) => { });
  5. }
  6. // 导入
  7. import request, { domain as url } from './modules/request.js';

9. 模块的合并导出


创建一个模块(merge.js)进行合并导出

  1. import * as user from './modules/user.js';
  2. import * as admin from './modules/admin.js';
  3. export { user, admin }

导入合并后的模块

  1. import * as api from './modules/merge.js';
  2. // 访问方式
  3. // api.user.成员
  4. // api.admin.成员

视频推荐


后盾人向军: JS模块化开发,编写高可用代码

本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!


从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!


本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。


本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。


若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。


本文链接:https://www.10zhan.com/biancheng/10295.html

标签: JavaScript
分享给朋友:

“JS ES6 模块化开发入门” 的相关文章

【说站】laravel实现自定义404页面并给页面传值

【说站】laravel实现自定义404页面并给页面传值

以 laravel5.8 为例,虽然有自带的404页面,但太简单,我们更希望能自定义404页面,将用户留在站点。实现的方式很简单,将自定义的视图文件命名为 404.blade.php,并放到 reso...

【说站】Thymeleaf报错Error resolving template “XXX”

【说站】Thymeleaf报错Error resolving template “XXX”

修改了一下开源项目的目录结构访问突然报错Error resolving template “XXX”可能原因有如下三种:第一种可能:原因:在使用springboot的过程中,如果使用thymeleaf...

【说站】用一句话就可以去除宝塔面板操作上的二次验证

【说站】用一句话就可以去除宝塔面板操作上的二次验证

用过宝塔的朋友应该都会发现,现在宝塔面板有些鸡肋的功能,删除文件、删除数据库、删除站点等操作都需要做计算题!不仅加了几秒的延时等待,还无法跳过!这时候就会有朋友在想,如何去除宝塔面板的二次验证,此篇文...

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

这篇文章主要介绍了详解Centos8 配置静态IP的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来学习一下!1. 查看自己的网关地址点击虚...

【说站】利用Webhook实现Java项目自动化部署

【说站】利用Webhook实现Java项目自动化部署

用webhook就能实现Java项目自动部署,其实原理很简单。费话不多说,直接往下看教程。1. 创建gitee仓库并初始化2. 在linux安装git3. 在宝塔的软件的商店里下载Webhook4....

【说站】vagrant实现linux虚拟机的安装并配置网络

【说站】vagrant实现linux虚拟机的安装并配置网络

一、VirtualBox的下载和安装1、下载VirtualBox官网下载:https://www.virtualbox.org/wiki/Downloads我的电脑是Windows的,所以下载Wind...