美文网首页
webpack介绍

webpack介绍

作者: 栗子daisy | 来源:发表于2019-09-26 17:43 被阅读0次
前端构建工具发展:Grunt,Gulp 和 Webpack
  • Grunt:从0到1,没有解决模块依赖,面向文件操作效率比较低
  • Gulp :做了改良, 基于Stream ,没能解决模块依赖
  • Webpack: 划时代的解决了模块依赖的问题
  1. 只支持JS模块,其他类型的模块通过loader转成JS模块。(CSS转成JS插入到DOM中;图片base64转成字符串,或文件拷贝后导出URL;babel-core)
  2. 所有的loader看做管道,进口是 一个字符串,然后经过加工,输出另一个字符串,多个loader可以像水管一样串联起来,很像java中的stream流。
babel-loader
返回编译的代码和sourcemap源码
最终编译出的代码中是否显示是 webpack 自己的配置,在 webpack.config.js 中添加一行代码打开sourcemap功能:devtool: 'eval-source-map'
style-loader 和 css-loader
  1. css-loader 的作用是处理css中的 @importurl 这样的外部资源
    1.1 processCss.js 中会调用 postcss 对 css 源码解析,遍历其中的 declaration 并抽离出 url 和 import 这两种依赖
    1.2 loader.js 会调用 processCss,根据它已经分析出的 url 和 import 依赖关系,在对应的代码中替换成 require,并拼接成段最终的JS返回
  2. style-loader 的作用是把样式插入到 DOM中,方法是在head中插入一个style标签,并把样式写入到这个标签的 innerHTML
file-loader 和 url-loader
  • file-loader 并不会对文件内容进行任何转换,只是复制一份文件内容,并根据配置为他生成一个唯一的文件名。

file-loader 的工作流程如下:

  1. 通过 loaderUtils.interpolateName 方法可以根据 options.name 以及文件内容生成一个唯一的文件名 url(一般配置都会带上hash,否则很可能由于文件重名而冲突)
  2. 通过 this.emitFile(url, content) 告诉 webpack 我需要创建一个文件,webpack会根据参数创建对应的文件,放在 public path 目录下。
  3. 返回 'module.exports = webpack_public_path + '+ JSON.stringify(url) + ‘;’ ,这样就会把原来的文件路径替换为编译后的路径
  • url-loader 并不是复制文件,而是把文件做base64编码,直接嵌入到CSS/JS/HTML代码中。
  1. 获取 limit 参数
  2. 如果 文件大小在 limit 之类,则直接返回文件的 base64 编码后内容
  3. 如果超过了 limit ,则调用 file-loader
bundle.js 内容分析

相关文章

  • webpack入门解析

    webpack 一. 认识webpack 1.1. webpack介绍 什么是webpack? 这个webpack...

  • webpack详解

    webpack 介绍 webpack 是什么 为什么引入新的打包工具 webpack 核心思想 webpack 安...

  • webpack介绍

    webpack是一个优秀的静态模块打包工具,它可以递归地构建出依赖关系,将所有模块打包成一个或多个bundle。 ...

  • Webpack介绍

    什么是Webpack webpack是一个模块打包器。它根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规...

  • webpack介绍

    简介 什么是模块打包?粗俗一点来讲,模块打包就是把一小坨一小坨的代码粘成一大坨。实际操作起来的时候当然还需要关注一...

  • webpack介绍

    前端构建工具发展:Grunt,Gulp 和 Webpack Grunt:从0到1,没有解决模块依赖,面向文件操作效...

  • webpack介绍

    1.什么是webpack webpack可以看做是模块打包机:它做的事情是,分析你的项目结构,找到JavaScri...

  • Webpack介绍

    What is webpack webpack是一个static module bundler(静态模块打包器)。...

  • webpack&gulp集成简介

    webpack简单介绍 webpack is a bundler for modules. The main pu...

  • [webpack 学习系列] 1. webpack 工具的由来

    webpack 工具的由来 什么是 webpack ?官网是这样介绍的,webpack is used to co...

网友评论

      本文标题:webpack介绍

      本文链接:https://www.haomeiwen.com/subject/eruguctx.html