一、webpack基本安装

1、创建webpack项目目录如webpackDemo,并进入webpackDemo;

2、 在node已经安装的前提下,打开命令行控制器,输入如下命令:

  1. npm init -y
  2. npm install webpack webpack-cli --save-dev //安装webpack webpack-cli
    (MacOS: sudo npm install webpack webpack-cli -g,sudo npm isntall webpack webpack-cli --save-dev)

命令执行结束后,会生成package.json、package_lock.json、node_modules文件。然后手动创建src目录与package.json平级,src目录下有index.html ,index.js 。

注:npm使用的是淘宝镜像,使用命令 npm install --registry=https://registry.npm.taobao.org express (临时使用);

  (MacOS 如果上面命令不生效,可以使用此命令: npm config set registry https://registry.npm.taobao.org).

二、webpack概念

1、 webpack有四个核心概念:entry(入口) 、output(输出)、loader、plugin(插件)。

entry(入口)

告诉webpack构建内部依赖图开始的模块;可以指定单入口起点文件或多入口起点文件。

  1. module.exports = {
  2. entry:"./src/index.js"
  3. }

output(输出

告诉webpack输出创建的bundles,以及如何命名文件。指定编译后的输出文件路径。

  1. const OUTPUT_FILE_NAME = "dist"
  2. module.exports = {
  3. entry:"./src/index.js",
  4. output: {
  5. filename: "[name].[contenthash:10].js", //输出文件名称, hash解决缓存问题
  6. path: path.resolve(__dirname,'dist') //输出文件路径
  7. }
  8. }

loader

loader可以让webpack可以处理非JavaScript文件,webpack本身只能处理JavaScript。

webpack配置loader有两个目标:

a).  test属性,用于被对应的loader进行转换的某个和某些文件;

b).  use属性,表示进行转换时,应该使用哪个loader;

  1. module.exports = {
  2. output: {
  3. filename: "[name].[contenthash:10].js", //输出文件名称, hash解决缓存问题
  4. path: path.resolve(__dirname, OUTPUT_FILE_NAME) //输出文件路径
  5. },
  6. module: {
  7. rules: [{
  8. //整理html的img资源,
  9. test: /\.html$/,
  10. use: ["html-loader"]
  11. },
  12. {
  13. //处理css资源
  14. test: /\.css$/,
  15. use: ["css-loader", "style-loader"]
  16. },
  17. {
  18. //处理JS资源
  19. test: /\.jsx?$/,
  20. use: ['file-loader']
  21. }]
  22. }
  23. }

插件plugins

loader用于转换某些类型,插件用于执行更广泛的任务。若使用一个插件,只需require(),然后添加到数组中。

  1. module.exports = {
  2. ...,
  3. plugins: [
  4. new HtmlWebpackPlugin({
  5. template: "./src/index.html",
  6. hash: true
  7. }),
  8. new MiniCssExtarctPlugin({
  9. filename: 'css/[name].[contenthash:10].css',
  10. path: path.resolve(__dirname,'dist')
  11. })
  12.  
  13. ]
  14. }

附全部代码:

package.json

  1. {
  2. "name": "webpack_demo",
  3. "version": "1.0.0",
  4. "description": "",
  5. "scripts": {
  6. "test": "echo \"Error: no test specified\" && exit 1",
  7. "watch": "webpack --watch",
  8. "start": "webpack --config webpack.config.js",
  9. "build": "webpack --config webpack.config.pro.js"
  10. },
  11. "keywords": [],
  12. "author": "",
  13. "license": "ISC"
  14. }

webpack.config.js

  1. const path = require("path");
  2. const HtmlWebpackPlugin = require("html-webpack-plugin");
  3. const MiniCssExtarctPlugin = require("mini-css-extract-plugin"); //将css从js中提取出来
  4.  
  5. const OUTPUT_FILE_NAME = "dist";
  6. module.exports = {
  7. entry: "./src/index.js",
  8. output: {
  9. filename: "[name].[contenthash:10].js", //输出文件名称,hash解决缓存问题,具体可见下面的解释
  10. path: path.resolve(__dirname, OUTPUT_FILE_NAME) //输出文件路径
  11. },
  12.  
  13. mode: "development", //开发环境,生产环境使用"production"
  14. module: {
  15. rules: [{
  16. //整理html的img资源,
  17. test: /\.html$/,
  18. use: ["html-loader"]
  19. },
  20. {
  21. //处理css资源
  22. test: /\.css$/,
  23. use: [
  24. //将css文件整合到JS文件中
  25. "css-loader",
  26. //创建style标签,将样式放入
  27. "style-loader",
  28. // css兼容性处理:postcss-->postcss-loader postcss-preset-env
  29. ]
  30. },
  31. {
  32. //处理JS资源
  33. test: /\.js$/,
  34. exclude: /node_modules/, //处理除了nodde_modules里的js文件
  35. loader: 'babel-loader' //用babel-loader处理
  36.  
  37. },
  38. {
  39. //处理图片资源
  40. test: /\.(png|svg|jpg|gif)$/,
  41. use: ['file-loader']
  42. },
  43. {
  44. // exclude: /\.(css|js|html)$/, //排除正则内的资源
  45. test: /\.(png|svg|jpg|gif)$/,
  46. // 这里是匹配条件,每个选项都接收一个正则表达式或字符串
  47. // test 和 include 具有相同的作用,都是必须匹配选项
  48. // exclude 是必不匹配选项(优先于 test 和 include)
  49. // 最佳实践:
  50. // - 只在 test 和 文件名匹配 中使用正则表达式
  51. // - 在 include 和 exclude 中使用绝对路径数组
  52. // - 尽量避免 exclude,更倾向于使用 include
  53. use: ['file-loader'],
  54. // options: {
  55. // name: "[hash:10].[ext]" //名字太长进行截取
  56. // }
  57. }
  58. ]
  59. },
  60. resolve: {
  61. extensions: ['.js', '.json']
  62. },
  63.  
  64. /*
  65. source-map:外联
  66. inline-source-map :
  67. */
  68. devtool: "source-map", //告诉webpack提供源代码
  69.  
  70. plugins: [
  71. // 将CSS文件从JS文件中提取出来
  72. new MiniCssExtarctPlugin({
  73. filename: 'css/[name].[contenthash:10].css',
  74. path: path.resolve(__dirname, OUTPUT_FILE_NAME)
  75. }),
  76. new HtmlWebpackPlugin({
  77. template: "./src/index.html"
  78. })
  79. ],
  80.  
  81. devServer: {
  82. port: 5000, //端口号
  83. contentBase: OUTPUT_FILE_NAME, //可访问问文件
  84. hot: true, //开启HMR热更新
  85. https: true, //使用https
  86. compress: true, // 启用压缩
  87. // proxy: {
  88. // "/": "http://localhost:3000", //使用代理路径
  89. // }
  90. },
  91.  
  92. /** code splitting 代码分割
  93. * 当单入口时,可以将 node_modules中代码单独打包成一个chunk;
  94. * 当多入口时,提取公共文件单独打包成一个chunk;
  95. */
  96. optimization: {
  97. splitChunks: {
  98. chunks: "all"
  99. }
  100. }
  101.  
  102. /**
  103. * 缓存:
  104. * Babel缓存
  105. * cacheDirectory:true
  106. * -->让第二次打包更快
  107. * 文件资源缓存:
  108. * hash :每次webpack构建是会生成一个唯一的hash值;
  109. * 问题:js和css使用同一个hash值,会导致缓存失效,可能值改变一个文件;
  110. * chunkhash:根据chunk生成的hash值,如果打包来自同一个chunk,那么hash是一样的
  111. * 问题:chunkhash是一样的,因为css是在js中被引用的,属于同一个chunk;
  112. * contenthash:根据文件内容生成hash值,不同文件的hash值不一样;
  113. * -->让代码上线运行缓存更好使用
  114. *
  115. */
  116.  
  117. /**
  118. * tree shaking:去除无用代码
  119. * 前提: 1.必须使用ES6模块化 2.开启production环境
  120. * 作用: 减少代码体积
  121. *
  122. * 在package.json中设置:
  123. * sideEffects:false 所有代码都没有副作用(都可以进行tree shaking)
  124. * 问题:可能会把css @babel/polyfill(副作用)文件干掉
  125. * sideEffects:["*.css",".less"] 不会进行tree shaking
  126. */
  127.  
  128. /**
  129. * HMR :hot module replacement 热模块
  130. * 作用:一个模块发生变化指挥重新打包这个模块,并不重新打包所有。提高打包速度。
  131. * 样式文件:可以通过HMR实现,style-loader已实现
  132. * JS文件:默认不使用HMR功能-->修改JS文件代码,只能处理非入口文件。
  133. * if(module.hot){
  134. * module.hot.accept("index.js",()=>{
  135. * //监听文件变化,一旦发生变法,其他地方不会重新打包,直接执行回调
  136. * }))
  137. * }
  138. * Html文件:默认不使用HMR功能,同时会出问题(无需做HMR功能)
  139. * 解决方案:修改entry入口,引入html文件
  140. *
  141. *
  142. */
  143. }

wenpack.config.pro.js

  1. const path = require("path");
  2. const HtmlWebpackPlugin = require("html-webpack-plugin");
  3. const MiniCssExtarctPlugin = require("mini-css-extract-plugin"); //将css从js中提取出来
  4. const OptiminizeCssAssetsPlugin = require("optimize-css-assets-webpack-plugin"); //压缩CSS
  5. const UglifyJsPlugin = require("uglifyjs-webpack-plugin");
  6.  
  7. const OUTPUT_FILE_NAME = "dist";
  8. module.exports = {
  9. entry: "./src/index.js",
  10. output: {
  11. filename: "js/[name].[contenthash:10].js", //输出文件名称,hash解决缓存问题,具体可见下面的解释
  12. chunkFilename: 'js/[name].[contenthash:10].bundle.js', // 依赖文件名称
  13. path: path.resolve(__dirname, OUTPUT_FILE_NAME), //输出文件路径
  14. publicPath: '/' // 公共路径
  15. },
  16. mode: "production", //生产环境
  17. module: {
  18. rules: [{
  19. test: /\.html$/,
  20. use: ["html-loader"]
  21. },
  22. {
  23. test: /\.css$/,
  24. use: [MiniCssExtarctPlugin.loader, "css-loader"]
  25. },
  26. {
  27. test: /\.jsx?$/,
  28. exclude: /node_modules/, //处理除了nodde_modules里的js文件
  29. loader: 'babel-loader' //用babel-loader处理es6
  30. },
  31. {
  32. test: /\.(png|svg|jpg|gif)$/,
  33. use: ['file-loader'],
  34. }
  35. ]
  36. },
  37. devtool: "source-map", //告诉webpack提供源代码
  38. plugins: [
  39. new HtmlWebpackPlugin({
  40. template: "./src/index.html",
  41. hash: true
  42. }),
  43. new MiniCssExtarctPlugin({
  44. filename: 'css/[name].[contenthash:10].css',
  45. path: path.resolve(__dirname, OUTPUT_FILE_NAME)
  46. }),
  47. /**
  48. * optimize-css-assets-webpack-plugin 会使webpack中自带的JS压缩失效,需要重新配置UglifyJsPlugin
  49. */
  50. new OptiminizeCssAssetsPlugin(),
  51. ],
  52.  
  53. /** code splitting 代码分割
  54. * 当单入口时,可以将 node_modules中代码单独打包成一个chunk;
  55. * 当多入口时,提取公共文件单独打包成一个chunk;
  56. */
  57. optimization: {
  58. splitChunks: {
  59. chunks: "all"
  60. }
  61. }
  62. }

webpack配置打包的更多相关文章

  1. webpack配置打包vue文件

    1.首先全局安装node,和npm.检查是否安装成功 2.新建一个文件下,进入该文件夹. 前先执行 npm init -y 然后就会在文件夹下出现一个package.json文件 然后执行 npm i ...

  2. webpack配置:less/sass文件打包和分离、自动处理css前缀、消除未使用的css及完整的webpack.config.js文件

    一.less文件打包和分离 1.要使用less,首先使用npm安装less服务:还需要安装Less-loader用来打包使用. npm install less --save-dev npm inst ...

  3. VUE 多页面打包webpack配置

      思路:多配置一个main的文件,用于webpack入口使用, 然后路由的导向也应该默认指向新组件,最后通过webpack构建出一个新的独立的html文件. 缺点:生成多个html会new出多个vu ...

  4. webpack配置自动打包重新运行npm run dev出现报错

    webpack配置自动打包重新运行npm run dev出现报错 运行npm run dev出现如下报错 Listening at http://localhost:8080(node:2328) U ...

  5. webpack项目打包配置

    webpack.config.js 文件中,其中“plugins”最为重要 var path = require("path"); const webpack = require( ...

  6. [webpack] 配置react+es6开发环境

    写在前面 每次开新项目都要重新安装需要的包,简单记录一下. 以下仅包含最简单的功能: 编译react 编译es6 打包src中入口文件index.js至dist webpack配置react+es6开 ...

  7. webpack入门和实战(一):webpack配置及技巧

    一.全面理解webpack 1.什么是 webpack? webpack是近期最火的一款模块加载器兼打包工具,它能把各种资源,例如JS(含JSX).coffee.样式(含less/sass).图片等都 ...

  8. Webpack配置示例和详细说明

    /* * 请使用最新版本nodejs * 默认配置,是按生产环境的要求设置,也就是使用 webpack -p 命令就可以生成正式上线版本. * 也可以使用 webpack -d -w 命令,生成用于开 ...

  9. vue-cli#2.0 webpack 配置分析

    目录结构: ├── README.md ├── build │ ├── build.js │ ├── check-versions.js │ ├── dev-client.js │ ├── dev-s ...

  10. webpack独立打包与缓存处理

    关于 微信公众号:前端呼啦圈(Love-FED) 我的博客:劳卜的博客 知乎专栏:前端呼啦圈 前言 先前写了一篇webpack入门的文章<webpack入门必知必会>,简单介绍了webpa ...

随机推荐

  1. 【Kubernetes】kubectl常用命令手册 -- 持续更新

    元信息 api列表: kubectl api-resources kubectl api-resources -o wide 用法查询: kubectl explain <>.<&g ...

  2. 【EF Core】主从实体关系与常见实体关系的区别

    上次老周扯了有关主.从实体的话题,本篇咱们再挖一下,主.从实体之间建立的关系,跟咱们常用的一对一.一对多这些关系之间有什么不同. 先看看咱们从学习数据库开始就特熟悉的常用关系--多对多.一对一.一对多 ...

  3. UE4构建基础和实践:一、概述

    序言 构建这个概念是和应用程序包及资源等相关的,它的特点是使用脚本控制一系列的任务的处理,以减少人力操作带来的成本和操作失误风险. 在UE的概念里,构建往往是和打包相关的(如编译.cook.压缩打包等 ...

  4. jquery解决跨域问题

    在Ajax请求的url不是本地或者同一个服务器下面的URI,最后虽然请求显示为200,但是不会返回任何数据,事实上简单来说请求同一个域名下的url或者说用不带http的绝对路径和相对路径请求是没有任何 ...

  5. DataGridView 控件分页

    在使用Winform开发桌面应用时,工具箱预先提供了丰富的基础控件,利用这些基础控件可以开展各类项目的开发.但是或多或少都会出现既有控件无法满足功能需求的情况,或者在开发类似项目时,我们希望将具有相同 ...

  6. AMH安装Nextcloud出现Access denied

    AMH部署了LAMP或者LNMP,然后常规安装Nextcloud,安装完成后跳转到首页就出现Access denied.Nextcloud的文件夹权限已经修改,可读写.http://127.0.0.1 ...

  7. 【Oracle】 instr函数与substr函数以及自制分割函数

    Oracle instr函数与substr函数以及自制分割函数 instr通常被用来作为判断某个字符串中是否含有执行字符串和将返回结果作为一些数据分割的数据,即有模糊查询like的作用,当返回的查询结 ...

  8. DHorse v1.3.0 发布,基于k8s的发布平台

    综述 DHorse是一个简单易用.以应用为中心的云原生DevOps系统,具有持续集成.持续部署.微服务治理等功能,无需安装依赖Docker.Maven.Node等环境即可发布Java.Vue.Reac ...

  9. 古早wp合集

    0x00 首先非常感谢大家阅读我的第一篇.本文章不仅仅是题解,一些细枝末节的小问题也欢迎大家一起解答. 小问题的形式如Qx:xxxxxxx? 欢迎发现小问题并讨论~~ N1nE是本人另外一个名字,目前 ...

  10. 带你读论文丨S&P2019 HOLMES Real-time APT Detection

    本文分享自华为云社区<[论文阅读] (09)S&P2019 HOLMES Real-time APT Detection(溯源图)>,作者: eastmount . 摘要 本文提出 ...