webpack打包工具使用

webpack打包工具的使用

什么是webpack?
官方给出的解释是: webpack 是一个现代化javascript应用程序的静态模块儿打包器(module bundler)。当webpack处理应用程序时,它会递归地构建一个依赖关系图,其中包含应用程序需要的每个模块儿,然后将所有这些模块儿打包成一个或者多个bundle,bundle英文意思时一捆,一包,一扎的意思,接触过juery的小伙伴应该对于bundles不陌生
在下载jquery文件时有jquery.js和query.bundles.js
带有bundles的字样的query文件时经过压缩的.

根据官方文档结合自己的理解来介绍:
从webpack v4.0.0开始,可以不引入一个配置文件。然而,webpack仍然还是高度配置的,在开始前你需要先理解四个核心概念:

入口(entry)
输出(output)
loader
插件(plugins)

入口(entry)

入口文件指示webpack应该使用哪一个模块儿,作为构建其内部依赖图的开始。进入入口七点后,webpack会找到哪些模块儿和库是有入口起点的(直接和间接)依赖的。

每一个依赖项随即被处理,最后输出称之为bundles的文件中(也就是将这些依赖模块儿打包称一个压缩的文件)可以在定义的webpack配置中配置entry属性,来指定一个入口文件起点(或者多个入口文件)。

module.exports = {
  entry: './path/to/my/entry/file.js'
};
出口(output)

output属性告诉webpack在哪儿输出它所创建的bundles,(就是需要将这些经过打包处理的文件放大那个文件夹下面)

const path = require('path');//载入path第三方包

module.exports = {
  entry: './path/to/my/entry/file.js', //入口文件
  output: {
    path: path.join(__dirname, 'dist'),  //打包后的文件所要放置的位置
    filename: 'my-first-webpack.bundle.js'
    //打包文件命名
  }
};

在了解到这两个概念入口和输出后我们来试着打包一个文件,首先你必须有安装node.js,因为webpack是在node环境下进行压缩的。

第一步:先新建一个文件夹,这里命名为mywebpack 然后将该文件加在终端打开
第二步:使用npm init -y 或者使用 npm init 初始化一个package.json文件,可以看到此时你的项目文件加夹下多了一个package.json文件
在这里插入图片描述

第三步:在mywebpack文件的根目录下新建一个webpack.config.js文件,这个可以随意命名,为了见名直译我就这样命名了

第四步: 我们再再mywebpack文件夹下面新建一个src空文件夹再src文件下面新建文件main.js(作为webpack打包时的入口文件),first.js,person.json文件

在这里插入图片描述
第五步由于我们需要一个绝对路径 需要借助path这第三包所以,使用npm i path 下载path包

在这里插入图片描述
第六步:在webpack.config.js文件写入:

const path = require("path");   //导入第三方包
module.exports = {

    entry:path.join(__dirname,"./src/main.js"),  
    //入口文件地址
    output: {
        path: path.resolve(__dirname, './dest'), //打包后的目录
        filename: 'dabao.js'  //打包后的文件名称
    }
    
}

第七步:使用webpack打包需要先使用npm安装webpack和webpack-cli,在cmd命令框中输入:

npm install webpack@4 webpack-cli -g

这是全局安装只需要安装一次,下次就不需要再安装
第八步:全局安装好后在终端执行webpack进行打包
在这里插入图片描述
出现这样的如上图所示的情况表示已经在指定文件路径下打包成功,我们一起来看一下
在这里插入图片描述文件目录下确实有增加了一个dest目录和一个js文件,我们再来看一下这个dabao.js文件
在这里插入图片描述
这就是经过webpack打包后的文件
下面我们在一个html文件中引入这个dabao.js文件并执行一下,我们在刚刚建好的dest文件中新建一个index.html文件,并引入dabao.js文件
在这里插入图片描述
运行一下index.html,并看控制台信息

在这里插入图片描述
上面介绍了entry和output使用,下面介绍一下plugin

plugin 插件

官方文档的解释是:插件可以用于执行范围更广的任务。插件的范围包括,从打包优化和压缩,一直到重新定义环境中的变量。接口功能极其强大,可以用来处理各种各样的任务。
想要使用一个插件你只需要require()它,然后把它添加到plugins数组中,多数插件可以通过选项(options)自定义,你也可以在一个配置文件中因为不同目的而多次使用同一个插件,这时需要通过使用new 操作符来创建它的一个实例

了解到上面的介绍后再来学习一下使用插件来压缩html模板
(一)配置HTML模板
1. 可以安装一个html-webpack-plugin插件来打包html模板(如:在src目录下新建demo.html文件,),并将该模板指向对应的入口文件。
安装html-webpack-plugin插件,如下:
npm i html-webpack-plugin@4 -D

2.接下来修改webpack.config.js配置文件,增加下面的内容:

const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');

module.exports = {
    entry: path.resolve(__dirname, './src/main.js'), //入口文件
    output: {
        path: path.resolve(__dirname, './dest'), //打包后的目录
        filename: 'dabao.js' //打包后的文件名称
    },
    //设置插件配置项
    plugins: [
        new HtmlWebpackPlugin({
            //在src目录下创建一个index.html页面当作模板来使用
            template: './src/index.html'
        })
    ]
}

在载入html-webpack-plugin模板后执行webpack,会有一个报错信息,报错信息如下
在这里插入图片描述
然后再使用npm i webpack@4 -D 执行完这个命令再次使用webpack命令执行一下就不报错了

再来看一下dest文件夹下index.html 发现index文件被压缩了并且增加了一条引入dabao.js文件
在这里插入图片描述
(二)打包css样式

在进行css打包之前,先介绍一下loader,loader是一个加载器,下面是官方给出的解释

loader

loader 让webpack去处理哪些非javascript文件(webpack自身只能理解javascript)。loader可以将所有类型的文件转化为webpack能够处理的有效模块儿,然后你就可以利用webpack的打包能力对他们进行处理

本质上,webpack loader 将所有类型的文件转化为应用程序的依赖图(和最终的bundle) 可以直接引入的模块儿

如果想要将css文件经过webpack打包输出到打包好的文件夹下面(dest),我们需要安装两个加载器分别是 style-loader 和 css-loader
命令: npm i style-loader@2.0.0 css-loader@3.6.0 -D
其中css-loader是负责解析css的,而style-loader则负责将css以内部样式表的形式嵌套html中,当使用插件拆分css时就不需要style-laoder了,因为会以外部样式表使用link到html中的

1.使用命令先来下载css-loader和style-loader加载器

在这里插入图片描述
2.下载完毕后,我们需要在webpack.config.js中配置一下loader加载器,loader是需要写在module中的,其中在使用css-loader和style-loader的时候我们注意一点 它是从右向左执行的,就是 先解析css文件在将css的样式嵌套到打包好的html文件中

const path = require('path');

const HtmlWebpackPlugin = require('html-webpack-plugin');

module.exports = {
    entry: path.resolve(__dirname, './src/app.js'), //入口文件
    output: {
        path: path.resolve(__dirname, './dest'), //打包后的目录
        filename: 'dabao.js' //打包后的文件名称
    },

    //module 当中配置loader
    module: {
        rules: [{
            test: /\.css$/,
            use: ['style-loader', 'css-loader'] //  loader就是要处理对应test规则的文件  loader的use规则,是从右向左处理
        }]
    },

    //设置插件配置项
    plugins: [
        new HtmlWebpackPlugin({
            //在src目录下创建一个index.html页面当作模板来使用
            template: './src/index.html'
        })
    ]
}

下面在src目录下创建一个css文件并写一些样式测试一下
在这里插入图片描述

并在src文件下使用require()将reset.css引入main.js中
为了方便能在打包文件中运行查看到效果,所以我给body加了一背景颜色
在这里插入图片描述上面的做法是将css样式嵌套到行内当中,如果我们想要将css样式拆分开来,应该怎样实现.

(三)拆分css(将入口文件中的依赖的内部样式,拆分到一个单独的css文件中)

通过使用 extract-text-webpack-plugin 插件 将src中的css文件拆分成一个单独的样式表。

1.需要先安装extract-text-webpack-plugins插件

npm i extract-text-webpack-plugin@next -D

== 注意目前extract-text-webpack-plugin不支持webpack4 ==

2.修改webpack.config.js文件将插件导入

const path = require("path");   //导入第三方包
const HtmlWebpackPlugin = require('html-webpack-plugin');
const ExtractTextWebpackPlugin = require('extract-text-webpack-plugin');
module.exports = {

    entry:path.join(__dirname,"./src/main.js"),
    //入口文件地址
    output: {
        path: path.resolve(__dirname, './dest'), //打包后的目录
        filename: 'dabao.js'  //打包后的文件名称
    },
     module:{
                rules: [{
                    test: /\.css$/,
                    //use: ['style-loader', 'css-loader'] //  loader就是要处理对应test规则的文件  loader的use规则,是从右向左处理
            use: ExtractTextWebpackPlugin.extract({ use: 'css-loader' }) //将css用link方式引入就不需要style-loader了
                }]
            },
    plugins:[
        new HtmlWebpackPlugin({
                        //在src目录下创建一个index.html页面当作模板来使用
                        template: './src/demo.html'
                    }),
            //css拆分后会把css文件放到dest目录下的styles.css中
        new ExtractTextWebpackPlugin('style.css')
    ]
    
}

然后再终端执行一下webpack命令
在这里插入图片描述我们来看一下dist目录下是否多了一个style.css文件,确实有
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值