初始化

mkdir webpack-demo   ->新建文件夹  
cd webpack-demo  ->进入文件夹

  • 第一步 npm init -y  -> 初始化项目(生成package.js)
  • 第二步 npm install webpack webpack-cli --save-dev  ->(下载webpack与webpack-cil)

加载资源

  • CSS: npm install --save-dev style-loader css-loader
  • 图片: npm install --save-dev file-loader
  • 数据: npm install --save-dev csv-loader xml-loader
  • ES6解析: npm install -D babel-loader @babel/core @babel/preset-env
     npm i -D style-loader css-loader file-loader csv-loader xml-loader babel-loader @babel/core @babel/preset-env

目前为止学习的所有插件:

  • 第三步 @babel/core @babel/preset-env autoprefixer babel-loader css-loader file-loader html-webpack-plugin mini-css-extract-plugin postcss-loader style-loader webpack webpack-cli webpack-dev-server
  • ->(把以学过的所有插件加载下来)

下载本地服务器

  • 第四步 npm i webpack-dev-server -D  -> (dev-server会生成一个虚拟服务器)

进入监视模式: webpack --watch

  • 进入监视模式之后不需要再次输入 npm run build 保存文件自动刷新页面

server的命令

  • 在浏览器打开: webpack-dev-server --open
    改变端口号: webpack-dev-server --open --port 3000
    直接打开html: webpack-dev-server --open --port 8080 --contentBase src

server的配置

  devServer: { // 开发服务器的配置
  port: 3000, // 端口号
  progress: true, //
  contentBase: './dist', // 打开的文件路径
  open: true // 是否打开
  },

分离css的插件

  • 插件: npm i -D html-webpack-plugin
  • new MiniCssExtractPlugin({
    filename: 'main.css'
    })
  • use里配置: MiniCssExtractPlugin.loader

自动添加CSS3前缀的插件

  • 插件: npm i -D postcss-loader autoprefixer
  • 然后配置一个 postcss.config.js 的文件
  • module.exports = {
    plugins: [require('autoprefixer')]
    }

压缩CSS的插件

  • 插件: npm -D optimize-css-assets-webpack-plugin;
  • const optimizeCss = require('optimize-css-assets-webpack-plugin');
  • optimization: { // 优化项
    minimizer: [
    new optimizeCss()
    ]
    },

      

压缩JS的插件

  • 插件: npm -D uglifyjs-webpack-plugin;
  • const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
  • new UglifyJsPlugin({ // 压缩JS
    cache: true, // 是否缓存
    parallel: true, // 是否压缩多个
    sourceMap: true // es6的源码映射
    }),

      

解析ES6的插件

  • 插件: npm install -D babel-loader @babel/core @babel/preset-env
  • 插件2(解析更高级的语法ES7): npm i -D @babel/plugin-proposal-class-properties
  • 插件3: npm i -D @babel/plugin-transform-runtime 依赖: @babel/runtime -save
  • {
    test: /.js$/,
    use: {
    loader: 'babel-loader',
    options: { // babel-loader 把es6转换成es5
    presets: [
    '@babel/preset-env'
    ]
    }
    }
    },

      

    babel-loader: 解析es6的loader
    @babel/core: 模块
    @babel/preset-env: 把高级语法转换成es5的插件

JS代码效验插件

插件: npm i eslint eslint-loader -D

解析less

  • {
    test: /.less$/,
    use: [
    MiniCssExtractPlugin.loader,
    'css-loader',
    'postcss-loader',
    'less-loader'
    ]
    }

      

  

设置HtmlWebpackPlugin

  • 插件: npm install --save-dev html-webpack-plugin
  • new HtmlWebpackPlugin({
    template: './src/index.html',
    filename: 'index.html',
    minify: {
    removeAttributeQuotes: true, // 删除index里的双引号
    collapseWhitespace: true, // 折叠空行 变成一行
    },
    // hash: true // 哈希戳
    }),

      

webpack.config.js配置

  

  • const path = require('path');
    const HtmlWebpackPlugin = require('html-webpack-plugin');
    const MiniCssExtractPlugin = require('mini-css-extract-plugin'); // 分离css的插件 module.exports = {
    mode: 'development', // 模式 默认两种 production-生产 development-开发
    entry: { // 入口
    index: './src/index.js'
    },
    devtool: 'inline-source-map', // 报错源
    module: {
    rules: [
    {
    test: /\.css$/,
    use: [
    MiniCssExtractPlugin.loader,
    'css-loader',
    'postcss-loader'
    ]
    },
    {
    test: /\.js$/, // normal 普通的
    use: {
    loader: 'babel-loader',
    options: { // babel-loader 把es6转换成es5
    presets: ['@babel/preset-env']
    }
    },
    include: path.resolve(__dirname, 'src'),
    exclude: /node_modules/
    },
    {
    test: /\.(png|svg|jpg|gif)$/,
    use: {
    loader: 'file-loader',
    options: {
    outputPath: '../imgs/'
    }
    }
    },
    { test: /\.(woff|woff2|eot|ttf|otf)$/, use: ['file-loader'] }
    ]
    },
    plugins: [
    new HtmlWebpackPlugin({ // 创建新的html
    template: './src/index.html',
    filename: 'index.html'
    }),
    new MiniCssExtractPlugin({
    filename: './css/main.css'
    })
    ],
    devServer: { // 打开浏览器
    contentBase: './dist',
    open: true,
    port: 3000,
    inline: true
    },
    output: { // 出口
    filename: 'bundle.js',
    path: path.resolve(__dirname, 'dist')
    }
    }

      

  

package.json scripts配置

  "build": "webpack",
  "watch": "webpack --watch",
  "start": "webpack-dev-server --open",
  "server": "node server.js"

设置HtmlWebpackPlugin

  • 插件: npm install --save-dev html-webpack-plugin
  • 蓝文件夹: 
    const HtmlWebpackPlugin = require('html-webpack-plugin');
    plugins: [
    new HtmlWebpackPlugin({
    title: 'Output Management'
    })
    ],

      

清理/dist文件夹

  npm install --save-dev clean-webpack-plugin
  const { CleanWebpackPlugin } = require('clean-webpack-plugin');
  new CleanWebpackPlugin(),

webpack4流程笔记的更多相关文章

  1. Spark任务流程笔记

    Spark学习笔记总结 02. Spark任务流程 1. RDD的依赖关系 RDD和它依赖的父RDD(s)的关系有两种不同的类型,即窄依赖(narrow dependency)和宽依赖(wide de ...

  2. webpack4.x笔记-配置基本的前端开发环境(一)

    webpack的基本使用 webpack 本质上是一个打包工具,它会根据代码的内容解析模块依赖,帮助我们把多个模块的代码打包.借用 webpack 官网的图片: 虽然webpack4.x的版本可以零配 ...

  3. webpack4 自学笔记三(提取公用代码)

    全部的代码及笔记都可以在我的github上查看, 欢迎star:https://github.com/Jasonwang911/webpackStudyInit/tree/master/commonT ...

  4. webpack4 自学笔记五(tree-shaking)

    全部的代码及笔记都可以在我的github上查看, 欢迎star: https://github.com/Jasonwang911/webpackStudyInit/tree/master/ThreeS ...

  5. webpack4 自学笔记四(style-loader)

    全部的代码及笔记都可以在我的github上查看, 欢迎star:https://github.com/Jasonwang911/webpackStudyInit/tree/master/css 引入- ...

  6. webpack4 自学笔记二(typescript的配置)

    全部的代码及笔记都可以在我的github上查看, 唤醒star: https://github.com/Jasonwang911/webpackStudyInit/tree/master/typesc ...

  7. webpack4 自学笔记一(babel的配置)

    所有代码都可以再我的github上查看,每个文件夹下都会有README.md,欢迎star: https://github.com/Jasonwang911/webpackStudyInit/tree ...

  8. memcached-1.4.20 主要启动流程笔记

    以下笔记主要是关注tcp模式下memcached的启动过程. main() 设置信号处理函数为sig_handler() 初始化系统设置,保存在全局变量settings里面 settings_init ...

  9. webpack4学习笔记(二)

    webpack打包各种javascript文件 (本文只是提供一个学习记录,大部分内容来自网络) 一,打包js文件和es6代码 1,webpack命令打包js文件 Tip: 在webpack4.x之前 ...

随机推荐

  1. centos7安装与配置ansible

    此次测试总共有三台机,分别如下: ansible服务器:10.0.0.20 client01:10.0.0.21 client02:10.0.0.22 一.安装ansible 1. python版本需 ...

  2. Flask03 路由控制(转换器)、反转、请求方法控制

    1 提出问题 如何实现前端传过去的路径时动态的(即:多个url对应一个url视图函数) 例如: 浏览器中输入 http://127.0.0.1:5000/test/good/ 或者 http://12 ...

  3. error C2039: “addTextureMesh”: 不是“pcl::visualization::PCLVisualizer”的成员

    error C2039: "addTextureMesh": 不是"pcl::visualization::PCLVisualizer"的成员 PCL 1.6 ...

  4. Cannot uninstall 'enum34'. It is a distutils installed project and thus we cannot accurately determine which files belong to it which would lead to only a partial uninstall.

    更新tensorflow时遇到报错 Found existing installation: enum34 1.0.4Cannot uninstall 'enum34'. It is a distut ...

  5. 整数划分——真正的递归经典例题(NYOJ——90)

    先注明学习博客的地址:(http://www.cnblogs.com/hoodlum1980/archive/2008/10/11/1308493.html) 题目描述:任何正整数n都可以写成n=n1 ...

  6. 聪明的kk (南洋理工—171)

    #include<iostream> using namespace std; ][]; ][]; int N, M; int dp(int i, int j) { ) return d[ ...

  7. C# - char类型的一些介绍

    Char C#里面的char,其实就是System.Char类型的别名,它代表一个Unicode字符(是这样吗?),占用两个字节. 例如:char c = ‘A’; char占用两个字节,也就是16位 ...

  8. Linux中关机和磁盘管理命令

    常用的关机命令 shutdown -h 关机 -r 重启 halt poweroff reboot 重启 logout 退出登录命令 磁盘管理命令 df -h 以1024进制计算最合适的单位显示磁盘容 ...

  9. 用SQL数据库做多表关联应怎样设计库结构20170527

    http://77857.blog.51cto.com/67857/143872/ 多表关联的话表之间必须得存在关系才行呢,这样建立外键约束就行了, 关系表中插入主表的主键做外键. 假设表1学生表st ...

  10. CF868F Yet Another Minimization Problem(决策单调性)

    题目描述:给定一个序列,要把它分成k个子序列.每个子序列的费用是其中相同元素的对数.求所有子序列的费用之和的最小值. 输入格式:第一行输入n(序列长度)和k(需分子序列段数).下一行有n个数,序列的每 ...