zoukankan      html  css  js  c++  java
  • webpack学习笔记一

    什么是webpack

     本质上,webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler)。当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个 bundle。详细使用可参考官方文档

    安装

    在官网中给出了两种安装方式:

    全局安装

    局部安装

     因为全局安装webpack时,会将项目中的webpack锁定到指定版本,并且在使用不同的webpack版本的项目中,可能会导致构建失败,所以官网中不推荐使用全局安装,我们接下来也是使用局部安装。

     

     项目初始化以后执行安装命令:  npm i webpack webpack-cli -D

    安装以后,查看安装版本

     此时会发现,直接执行webpack -v会报错,因为只是针对全局的命令,项目里面的话,需要借助npx,包括后面的其他webpack相关命令也是这样的。

    安装完成以后,在项目根目录新建文件夹src,然后在src下新建index.js文件。

     做了最简单的操作以后,就可以进行打包了:

     这里使用命令npx webpack进行打包,没有指定入口文件,代表采用默认路径下(根目录-->src-->index.js)的文件作为入口文件,如果要采用其他文件作为入口文件,则需要在打包是进行指定:

     上面这个就是指定根目录下的test.js作为入口文件。

    打包完成以后,就会在根目录下生成一个dist文件夹。

     webpack配置文件

    默认配置文件

    在上面的简单操作中,我们没有对项目进行任何配置,这种零配置的项目是很弱的,在正常项目中,总会根据特定的需求进行相应的配置。

    刚刚执行命令npx webpack test.js时,表示使用根目录下的test.js为入口文件进行打包处理,默认打包后的模块名称为main.js,放在根目录下的dist文件夹下。零配置的话,全部都是默认的,要想进行自定义,就需要使用到webpack的配置文件进行自己想要的配置。

    webpack有默认的配置文件webpack.config.js,刚刚上面的两个打包命令:

     

     都没有指定配置文件,则代表使用默认的配置文件webpack.config.js进行打包(上面项目中不存在webpack.config.js这个文件,则表示零配置。如果项目中存在这个配置文件,并且打包的时候,没有指定配置文件,那么就会默认选中webpack.config.js)。

    自定义配置文件

    除了上面的默认配置文件以外,我们也可以自定义一个配置文件,然后在打包的时候进行指定就可以了:

    这个就表示指定使用webpackconfig.js文件作为配置文件进行打包。

    webpack.config.js

    const path = require("path");
    module.exports={
        mode:'development',  //模式:none  development  production
        // entry:"./src/index.js",   //入口文件,不指定打包后的名称,则默认为main.js
        entry:{
            main:"./src/index.js"   //指定打包后的文件名称为main.js
        },
        output:{
            path:path.resolve(__dirname,'dist'),  //打包后的文件存放的位置,必须是绝对路径
            filename:"[name].js"    //打包后的文件的名称,[]表示占位符,表示此处使用前面指定的名称,如果这里进行指定,则会覆盖前面的指定
        }
    }

    除了上面这些简单配置外,还可以修改打包命令,只需要修改package.json里的scripts就可以了。

     

    修改为:

     

    此时,我们就可以执行命令npm run bundle进行打包了。(因为npm run执行的命令,会优先使用项目工程里的包,效果和npx类似,所以这里不需要使用添加npx)

     loader和module

    loader是模块转换器,用于把模块原内容按照需求转换成新内容。webpack是模块打包工具,而模块不仅仅是js,还可以使css、图片或者其他格式,但是webpack默认只知道如何处理js模块,那么其他格式的模块处理,就需要借助于loader了(loader里的配置,单个是对象,多个用数组,遵循自右向左,从下到上的顺序)。

    module是模块,在webpack里一切皆模块,一个模块对应着一个文件。webpack会从配置的Entry开始递归找出所有依赖的模块。

    当webpack处理到不认识的模块时,需要在webpack中的module处进行配置,当检测到时什么格式的模块,就使用什么loader来处理。

      

     上面,在入口文件中引入了一个图片模块以后,在进行打包,就直接报错了,这个时候,我们就需要使用到一个file-loader了。

    file-loader

    处理静态资源模块,就是当我们需要模块(txt、svg、csv、excel、图片等)仅仅是从源代码移动到打包目录的时候,就可以使用file-loader来处理了。其作用原理就是把打包入口中识别出的资源模块,移动到输出目录,并且返回一个地址名称。

    要使用file-loader,首先需要进行安装:npm install file-loader -D

    然后在配置文件webpack.config.js中配置使用:

     再执行上面的打包操作:

      

     最后的打包文件中,除了默认的出口文件外,还多了一个图片资源,就是上面引入的那个图片。但是此时有个问题,这个图片的名称改变了,因此,我们还需要进行相关的配置options。

      

     url-loader

    可以处理file-loader所有的事情,但是遇到jpg格式的模块,会把该图片转换成base64格式字符串,并打包到引入的js里。对小体积的图片比较合适,大图片就不合适了。

    css-loader、style-loader和sass-loader

    • css-loader用于分析css模块之间的关系,并合并成一个css
    • style-loader会把css-loader生成的内容,以style挂载到页面的head部分
    • sass-loader用于把sass语法转换成css,依赖node-sass模块

     更多loader配置,可以参看官网loader介绍列表。

    Plugins

    plugin可以在webpack运行到某个阶段的时候,帮你做一些事情,类似于生命周期的概念。

    html-webpack-plugin

    html-webpack-plugin会在打包结束后,自动生成一个html文件,并把打包生成的js模块引入到该html中。

    首先安装进行安装:npm install --save-dev html-webpack-plugin

    并在项目根目录下新建一index.html

     然后在配置文件中进行相关配置:

     最后进行打包:

     其中的app.html就是按照上面的配置生成的:

    多入口配置

    在上面配置的基础上,我们在src下新建两个js,然后在入口处进行配置:

     然后打包,此时在dist文件下对应生成了3个出口文件,但是,在app.html文件中,却只引入了一个。

     多出口配置

        

     这样生成的每个html文件里,相应引入配置的js文件了。

    clean-webpack-plugin

    目前,我们每次进行打包的时候,都需要先删除dist文件夹,然后再打包,否则之前同名的文件被覆盖了,但是不同名的文件会被保留。现在clean-webpack-plugin就可以替我们完成打包前的清除工作。

    首先进行安装:

    npm install --save-dev clean-webpack-plugin

    然后使用就可以了

    mini-css-extract-plugin

    前面style-loader会把css-loader生成的内容,以style挂载到页面的head部分。这里mini-css-extract-plugin这是将css形成一个单独的文档。

    首先进行安装:npm install --save-dev mini-css-extract-plugin

    然后引入并使用:

     

     

  • 相关阅读:
    记录一次阿里云服务器被攻击的经历
    post字符 特殊字符处理【转】
    forkjoin框架疑问记录
    centos7 安装 maven 和ant git 以及 rocketmq 4.2安装过程(安装成功,调用失败)
    IntelliJ Idea编译报错:javacTask: 源发行版 1.8 需要目标发行版 1.8
    记录一次json转换的经历
    maven项目在idea下右键不出现maven的解决办法
    Mac系统查看端口占用和杀死进程
    委托所想
    win8中的参数传递
  • 原文地址:https://www.cnblogs.com/yuyujuan/p/11588184.html
Copyright © 2011-2022 走看看