模块化主要是用来抽离公共代码,隔离作用域,避免变量冲突等。将一个复杂的系统分解为多个模块以方便编码。
会讲述以下内容
同步加载
CommonJS api是以在浏览器环境之外构建 JS 生态系统为目标而产生的项目
如果没有写后缀名Node会尝试为文件名添加.js、.json、.node后再搜索。
.js件会以文本格式的JavaScript脚本文件解析,.json文件会以JSON格式的文本文件解析,.node文件会以编译后的二进制文件解析。
异步加载(对象)
"Asynchronous Module Definition"(异步模块定义),是由RequireJS提出的
AMD核心实现
function require (url, callback) {
// url可以换成List,然后遍历;
var $script = document.createElement('script');
$script.src = url;
// 利用onload回调,实现依赖加载
$script.onload = function (e) {
// 省略callback 检测
callback();
}
document.body.appendChild($script);
}
按需加载
由玉伯提出的(seajs),按需解析加载模块(代价挺大的),需要使用把模块变为字符串解析一遍才知道依赖了那些模块
CMD核心实现
// ajax,怕忘了原生ajax怎么写。顺手写一个
function myAjax (url, callback) {
var xhr = new XMLHttpRequest();
xhr.open('get', url);
xhr.send();
xhr.onreadystatechange = function () {
if (request.readyState === 4) {
if (request.status === 200) {
return callback(request.responseText);
} else {
// 省略...
}
} else {
// 省略...
}
}
}
// 实现
function require(url) {
myAjax(url, function(res) {
// 此时 res 的对应JS的 String形式
// 解析 省略
// 执行
eval(res);
});
}
兼容AMD,CommonJS 模块化语法。
UMD源码解析
(function (root, factory) {
// 判断是否支持AMD(define是否存在)
if (typeof define === 'function' && define.amd) {
define(['b'], factory);
// 判断是否支持NodeJS模块格式(exports是否存在)
} else if (typeof module === 'object' && module.exports) {
module.exports = factory(require('b'));
// 前两个都不存在,则将模块公开到全局(window或global)
} else {
root.returnExports = factory(root.b);
}
} (this, function (b) {
// ...
}));
加载引用
不能处于代码块中
为了实现编译时加载
不能使用表达式和变量 等运行时加载的语法
import会被编译成 require/exports (CommonJS规范)
1. 直接引入
import xxx.js或者import xxx.css会像添加<script>和<link>标签一样注入到全局中去
2. commonjs同步语法
webpack会将require('abc.js')打包进引用它的文件中。以对象的形式获取。
3. commonjs异步加载
webpack(require.ensure):webpack 2.x 版本中的代码分割。
在commonjs中有一个Modules/Async/A规范,里面定义了require.ensure语法。webpack实现了它,作用是可以在打包的时候进行代码分片,并异步加载分片后的代码。 此时list.js会被打包成一个单独的chunk文件。像这样:1.d6f343b727f5923508bf.js
例如:vue路由懒加载const Foo = () => import('./Foo.vue')
manifest
manifest文件是最先加载的,manifest是在vendor的基础上,再抽取出要经常变动的部分,通过manifest.js文件来管理bundle文件的运行和加载。(比如关于异步加载js模块部分的内容)
webpack v4.6.0+ 添加了预取和预加载的支持
import(/* webpackPrefetch: true */ 'LoginModal');
会生成 <link rel="prefetch" href="login-modal-chunk.js"> 并追加到页面头部
整理不易,喜欢请 star,https://github.com/zhongmeizhi
ES6之前已经出现了js模块加载的方案,最主要的是CommonJS和AMD规范。commonjs主要应用于服务器,实现同步加载,如nodejs。AMD规范应用于浏览器,如requirejs,为异步加载。
Node的https模块:HTTPS服务器使用HTTPS协议,需要证书授权,SSL安全加密后传输,使用443端口
最新版的 node 支持最新版 ECMAScript 几乎所有特性,但有一个特性却一直到现在都还没有支持,那就是从 ES2015 开始定义的模块化机制。而现在我们很多项目都是用 es6 的模块化规范来写代码的,包括 node 项目
module每个文件就是一个模块。文件内定义的变量、函数等等都是在自己的作用域内,都是自身所私有的,对其它文件不可见。在module中有一个属性exports,即:module.exports。它是该模块对外的输出值,是一个对象。
模块是Node.js 应用程序的基本组成部分,文件和模块是一一对应的。换言之,一个 Node.js 文件就是一个模块,这个文件可能是JavaScript 代码、JSON 或者编译过的C/C++ 扩展。Node.js 提供了 exports 和 require 两个对象
ES6中引入了模块(Modules)的概念,相信大家都已经挺熟悉的了,在日常的工作中应该也都有使用。本文会简单介绍一下ES模块的优点、基本用法以及常见问题。
ES6中 export 和 export default 与 import使用的区别,使用 react native 代码详解,现在流行的前端框架,angular+ 主要使用 export 导出模块,react native 中使用 export default 导出模块,如今编辑器非常强大,安装插件会自动弹出模块名称,知道其导出怎么使用就可以了
export与export default均可用于导出常量、函数、文件、模块;你可以在其它文件或模块中通过import+(常量 | 函数 | 文件 | 模块)名的方式,将其导入,以便能够对其进行使用;
网上有很多关于export和export default的文章,他们大部门都是只讲了用法,但是没有提到性能,打包等关键的东西。大家应该应该能理解import * from xxx会把文件中export default的内容都打包到文件中,而import {func} from xxx只会把文件中的func导入
配置 webpack ProvidePlugin 全局引入,假设要使用到 jquery,那么可以通过配置 webpack 的 ProvidePlugin 的插件来全局引入;另外一种比较靠谱的方法是将第三方模块打包成插件,如我需要全局使用 echarts,那么在 src 目录下新建一个 lib
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!