什么是webpack? 以及其使用方法

什么是Webpack

WebPack可以看做是模块打包机:它做的事情是,分析你的项目结构,找到JavaScript模块以及其它的一些浏览器不能直接运行的拓展语言(Scss,TypeScript等),并将其转换和打包为合适的格式供浏览器使用。

为什么要使用Webpack

现今的很多网页其实可以看做是功能丰富的应用,它们拥有着复杂的JavaScript代码和一大堆依赖包。为了简化开发的复杂度,前端社区涌现出了很多好的实践方法。

*模块化,让我们可以把复杂的程序细化为小的文件。

*类似于TypeScript这种在JavaScript基础上拓展的开发语言:使我们能够实现目前版本的JavaScript不能直接使用的特性,并且之后还能转换为JavaScript文件使浏览器可以识别;

*Scss,less等CSS预处理器

Webpack

1.会wepbakc的前置知识:会用node.js安装一个包( npm install xxxx --save-dev)

2.webpack核心:

  • entry:入口
  • output:出口
  • loader:资源转换器
  • plugin:插件
  • mode:模式

3.webpack目前最新稳定版本:4.43

Webpack的使用

1.创建一个项目目录:webpack_vue

2.创建一个package.json文件

npm init -y

3.安装webpack,webpack-cli

npm install webpack webpack-cli --save-dev

简写:npm i webpack webpack-cli -D

检测是否安装成功:

./node_modules/.bin/webpack -v
通过package.json中的scripts脚本来测试   
http://www.ruanyifeng.com/blog/2016/10/npm_scripts.html
npm info webpack

4.在项目根目录下创建一个src,并建立一个index.js

5.在项目根目录下运行npm run build

会构建成一个dist目录,并生成一个main.js文件

wabpack4.x 默认是零配置:

即默认的入口:src/index.js
默认的出口:dist/main.js

手动配置:

 入口:src/main.js
 出口:dist/bundle.js

6.如果手动配置,必须要创建webpack配置文件,来执行

默认webpack配置文件:webpack.config.js

黄色警告如何解决:通过配置mode
如何自动清理打包的垃圾文件:

第一步: npm install --save-dev clean-webpack-plugin

第二步: 在webpack.config.js中引入

const { CleanWebpackPlugin } = require(‘clean-webpack-plugin’);

第三步:通过plugins实例化

        module.exports = {
           ...
            plugins: [
            new CleanWebpackPlugin(),
    
            ......
        };

基于webpack的服务器环境:webpack-dev-server;

npm install webpack-dev-server -D

通过devServer来配置:port,baseContent

 devServer: {
        port: 9999,
        contentBase: path.join(__dirname, 'dist'),
    }

如何实现自动构建构的文件自动注入index.html:

安装html-webpack-plugin

npm install html-webpack-plugin

引入:

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

添加到plugins中:

 plugins: [
     。。。
    new HtmlWebpackPlugin({
        template: './index.html',  //读取模板的入口文件
        filename:'index.html'  //生成打包后的html文件
    }),
]

说明:webpack可以将node服务端的JS代码通过构建直接运行在浏览器上

webpack支持多种模块化规范:AMD,CMD,CommonJS,ES6 modules

webpack默认识别的文件:.js,.json文件格式

loader:让webpack识别其他类型的文件,例如:css,png,svg,less,sass…

识别css:style-loader,css-loader

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值