为什么会考虑模块?

  webapp,页面初始化和使用过程中会加载越来越多的javascript代码

  --- 给前端的开发流程和资源组织带来挑战

  ---前端需要模块系统

模块系统是干什么的呢?

  模块的定义

     依赖

     导出

现有的模块规范有哪些?

  commonjs

    例子: 服务器端的nodejs

    思想: 允许模块通过require方法来同步加载所要依赖的其他模块,然后通过exports或module。exports来导出需要暴漏的接口

    缺点:不能非阻塞并行加载多个模块

  amd

    主要接口: define(id?,dependencies?,factory)对于依赖的模块提前执行

    缺点:代码的阅读和书写比较困难,不通用

    优点:并行加载多个模块,适合在浏览器中异步加载模块

    例子: curl,requirejs

  cmd

    和amd很相似,尽量保持简单,兼容性好

    define(function(require,exports,module){

      var $ = require('jquery');

      exports.xxx

      module.exports=

    });

    模块的加载逻辑很重?

    例子:seajs

  es6模块

    思想: 静态化,在编译时就能确定模块的依赖关系,以及输入和输出的变量

      import ‘jquery’

      export function(){}

      module “localmodule”{}

    缺点: 兼容性

    例子:babel

理想的模块系统是怎么样的呢?

  1. 可以兼容多种模块风格

  2. css、图片、字体等也需要模块化

    资源会以各种方言的形式存在,比如coffeescript、less、sass、众多的模版库等

    如何做到让require能加载各种资源?

      静态分析

        在编译的时候,对整个代码进行静态分析,分析出各个模块的类型和他们依赖关系,然后将不同类型

        的模块提交给适配的加载器来处理

模块的加载?

  极端模式:每个模块文件单独加载

       把所有模块打包成一个文件然后只请求一次

  分块传输模式:按需进行懒加载

         需要一个对整个代码库中的模块进行静态分析、编译打包的过程

  

webpack 往右一点之 “模块这个东西”的更多相关文章

  1. webpack 往右一点之 “你好,初次见面”

    webpack  模块打包器 模块化工具的目标: 将依赖树拆分成按需加载的块 初始化加载的耗时尽量少 各种静态资源都可以视作模块 将第三方库整合成模块 自定义打包逻辑 适合大项目

  2. webpack打包之无依赖模块

    一.入口文件main.js // main.js console.log('webpack'); 二.出口文件bundle.js 1.浏览代码 2.本质 // 实际就是一个自执行函数 (functio ...

  3. Webpack 常见静态资源处理 - 模块加载器(Loaders)+ExtractTextPlugin插件

    Webpack 常见静态资源处理 - 模块加载器(Loaders)+ExtractTextPlugin插件 webpack系列目录 webpack 系列 一:模块系统的演进 webpack 系列 二: ...

  4. 记录一下webpack好用的node模块

    postcss-loader autoprefixer: 自动添加css前缀 css-loader: 能在js文件中导入css(配合React比较好,我猜) style-loader: 将所有的计算后 ...

  5. webpack 代码分割一点事

    webpack 俨然已经成为前端最主流的构建工具,其功能多种多样,我们今天就来分析下关于代码分割这部分的一点事,并在最后讲述如何实现在webpack编译出的代码里手动添加一个异步chunk. 什么是c ...

  6. .4-浅析webpack源码之convert-argv模块

    上一节看了一眼预编译的总体代码,这一节分析convert-argv模块. 这个模块主要是对命令参数的解析,也是yargs框架的核心用处. 生成默认配置文件名数组 module.exports = fu ...

  7. .15-浅析webpack源码之WebpackOptionsApply模块-plugin事件流总览

    总体过了一下后面的流程,发现Compiler模块确实不适合单独讲解,这里继续讲解后面的代码: compiler.options = new WebpackOptionsApply().process( ...

  8. .7-浅析webpack源码之WebpackOptionsDefaulter模块

    WebpackOptionsDefaulter模块 通过参数检测后,会根据单/多配置进行处理,本文基于单配置,所以会进行到如下代码: if (Array.isArray(options)) { com ...

  9. .6-浅析webpack源码之validateSchema模块

    validateSchema模块 首先来看错误检测: const webpackOptionsValidationErrors = validateSchema(webpackOptionsSchem ...

随机推荐

  1. WinZip Registry Optimizer 初体验

    WinZip Registry Optimizer是来自著名压缩软件WinZip开发团队的一种可以修复.组织和整理Windows注册表的应用程序,它可以删除无效的注册表条目,整理碎片从而提升系统性能, ...

  2. window.onload用法详解:

    网页中的javaScript脚本代码往往需要在文档加载完成后才能够去执行,否则可能导致无法获取对象的情况,为了避免这种情况的发生,可以使用以下两种方式: 一.将脚本代码放在网页的底端,这样在运行脚本代 ...

  3. JQuery 阻止js事件冒泡 阻止浏览器默认操作

    //阻止事件冒泡 event.stopPropagation(); //阻止浏览器默认操作 event.preventDefault(); 代码不一定能执行,写给自己看的. 事件冒泡: <a h ...

  4. 你应该知道的那些Android小经验

    原文出处:http://jayfeng.com/ 做Android久了,就会踩很多坑,被坑的多了就有经验了,闲暇之余整理了部分,现挑选一些重要或者偏门的“小”经验做个记录. 查看SQLite日志 ad ...

  5. 基于jQuery的email suggest插件

    最近项目中有表单提交的地方需要用户填写邮箱,PM(产品经理)和运营都强烈要求在用户填写邮箱的时候出现suggest列表,简化用户输入的填写流程.我考虑了下,这个应该也是经常会用到的功能,细心的朋友可能 ...

  6. 开机自动执行脚本 与 update-rc.d

    http://coderbee.net/index.php/linux/20130524/141 update-rc.d    script_name defaultsupdate-rc.d    s ...

  7. EX:The underlying connection was closed: Could not establish trust relationship for the SSL/TLS secure channel.

    EX:The underlying connection was closed: Could not establish trust relationship for the SSL/TLS secu ...

  8. js 常用方法

    1: 五秒后跳出提示框 setTimeout("alert('已经过了五秒了')",5000) 2:  十秒后自动关闭窗口 <script language="ja ...

  9. ubuntu12.04+Elasticsearch2.3.3伪分布式配置,集群状态分片调整

    目录 [TOC] 1.什么是Elashticsearch 1.1 Elashticsearch介绍 Elasticsearch是一个基于Apache Lucene(TM)的开源搜索引擎.能够快速搜索数 ...

  10. 解决魅族MX5卸载debug-app不干净,导致安装、升级不成功的问题

    环境:魅族MX5,Android 5.1 问题:开发app使用真机调试后,在桌面上拖动图标卸载app-debug.apk,然后安装签名版本的app-release.apk提示替换xxx版本,按确定后提 ...