一、webpack-dev-server

1、安装

cnpm   install  webpack-dev-server  -D

2、作用

开启一个web服务,监听文件的变化并自动刷新网页,做到实时预览。支持 Source Map,以方便调试

3、基本使用

devServer:{
   contentBase:path.join(__dirname,"dist"),
   host:"127.0.0.1"
   open:true,
   proxy:{
       "/api":{
           target:"http://www.baidu.com",
           changeOrigin:true
      }
  },
   prot:8080
}
  • contentBase:本地服务器加载页面的目录

  • host:指定使用的主机地址

  • hot:热模块替换

  • hotOnly:在没有页面刷新的情况下启用热模块替换

  • open:告诉dev-server在服务器启动后打开浏览器。将其设置true为打开默认浏览器。

  • proxy:代理 服务器代理跨域

  • prot:设置端口号

二、热模块更新 (Hot Module Replacement)

1、作用

假设当我们的模块样式发生改变的时候只需要更新css即可,不需要将整个页面进行重新加载。方便用于调试css

2、基本使用

constwebpack=require("webpack");
module.exports ={
   devServer:{
       contentBase:"./dist",
       open:true,
       port:8080,
       hot:true,//开启Hot Module Replacement
       hotOnly:true
  },
   plugins:[
       newwebpack.HotModuleReplacementPlugin()//webpack自带的插件
  ]
}

三、sourceMap配置(问题)

sourceMap是一个映射关系,它会将我们打包后的文件出错的部分对应打包前文件出错的部分,这样对于我们的代码调试是非常方便的

sourcemap是为了解决开发代码与实际运行代码不一致时帮助我们debug到原始开发代码的技术

注意如果配置了sourceMap后打包的速度回变慢

module.exports={
   devtool:"none"//关闭
   devtool:"source-map"
   devtool:"inline-source-map"//会将映射的文件已字符串的形式放入打包文件中
}

module.exports={
   devtool:"cheap-module-eval-source-map",//dev环境
   devtool:"cheap-module-source-map",//线上环境
}

inline:会将映射的文件已 字符串的形式放入打包文件中去

cheap:只会负责业务代码中的错误,不会负责node_modules中的错误

module:可以让source负责node_modules中的错误

四、resolve

Webpack 在启动后会从配置的入口模块出发找出所有依赖的模块,Resolve 配置 Webpack 如何寻找模块所对应的文件。Webpack 内置 JavaScript 模块化语法解析功能,默认会采用模块化标准里约定好的规则去寻找,但你也可以根据自己的需要修改默认的规则

alias

配置项通过别名来把原导入路径映射成一个新的导入路径

resolve:{
 alias:{
   components: path.join(__dirname,'./src/components/')
}
}

extensions

在导入语句没带文件后缀时,Webpack 会自动带上后缀后去尝试访问文件是否存在。resolve.extensions 用于配置在尝试过程中用到的后缀列表,默认是['.js', '.json']

也就是说当遇到 require('./data')  这样的导入语句时,Webpack 会先去寻找  ./data.js文件,如果该文件不存在就去寻找./data.json 文件, 如果还是找不到就报错

resolve: {
       extensions: ['.ts', '.tsx', '.js'],
     
},

五、webpack-merge

分离配置文件

我们在根目录下创建config文件夹,并创建四个配置文件:

  • webpack.comm.js 公共环境的配置文件

  • webpack.development.js 开发环境下的配置文件

  • webpack.production.js 生产环境下的配置文件

  • webpack.parts.js 各个配置零件的配置文件

如果配置文件被分成了许多不同的部分,那么必须以某种方式来组合他们,通常就是合并数组和对象,webpack-merge很好的做到了这一点。

webpack-merge做了两件事:它允许连接数组并合并对象,而不是覆盖组合

安装

cnpminstallwebpack-merge--save-dev

设置各个配置文件的连接

constbaseWebpackConfig=requie("./config/base.config.js");
constwebpackMerge=require('webpack-merge');
constwebpackConfig=webpackMerge(baseWebpackConfig, {
 
})

module.exports=webpackConfig

【webpack4.0】---webpack的基本使用(三)的更多相关文章

  1. [转]webpack4.0.1安装问题和webpack.config.js的配置变化

    本文转自:https://blog.csdn.net/jiang7701037/article/details/79403637 The CLI moved into a separate packa ...

  2. 【webpack4.0】---webpack的基本使用(一)

    一.初识webpack 1.什么是webpack? WebPack可以看做是模块打包机:它做的事情是,分析你的项目结构,找到JavaScript模块以及其它的一些浏览器不能直接运行的拓展语言(Scss ...

  3. webpack4.0.1安装问题和webpack.config.js的配置变化

    The CLI moved into a separate package: webpack-cli. Please install 'webpack-cli' in addition to webp ...

  4. webpack工具学习 构建简单vue项目(不依赖vue-cli) webpack4.0

    目的用webpack构建简单前端项目 1.npm init   (npm init -y)  形成package.json 2.npm install --save-dev webpack  形成 n ...

  5. 史上最走心webpack4.0中级教程——配置之外你应该知道的事

    <webpack4.0各个击破系列>适合不满足于只会配置webpack但一时间又看不懂源码的中级读者.我没法保证这个系列是最好的,但至少能保证每一篇博文都跟那些Ctrl+C和Ctrl+V的 ...

  6. webpack4.0各个击破(1)—— html部分

    webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...

  7. webpack4.0各个击破(2)—— CSS篇

    webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...

  8. webpack4.0各个击破(4)—— Javascript & splitChunk

    目录 一. Js模块化开发 二. Js文件的一般打包需求 三. 使用webpack处理js文件 3.1 使用babel转换ES6+语法 3.2 脚本合并 3.3 公共模块识别 3.4 代码分割 3.5 ...

  9. webpack4.0各个击破(6)—— Loader篇

    webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...

  10. webpack4.0各个击破(8)—— tapable篇

    webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...

随机推荐

  1. JAVA判断URL地址是否非法

    /** * 判断请求url是否非法 * @param url * @return */ public static boolean isValidRequestUri(String url) { if ...

  2. c++设计模式概述之代理

    代码写的不规范,目的是缩短文章篇幅,实际中请不要这样做. 1.模式的结构 代理模式的主要角色如下: A.抽象主题(Subject)类:通过接口或抽象类声明真实主题和代理对象实现的业务方法. B.真实主 ...

  3. 【LeetCode】102. Binary Tree Level Order Traversal 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 DFS BFS 日期 题目描述 Given a bi ...

  4. git 上传项目到远程仓库

    电脑安装git客户端.注册github账号并登陆 到本地项目文件夹右键选择git bash here 输入个人信息(代码提交者) git config --global user.name " ...

  5. salesforce零基础学习(一百一十)list button实现的一些有趣事情

    本篇参考: salesforce零基础学习(九十五)lightning out https://developer.salesforce.com/docs/component-library/docu ...

  6. Trial-faster-rcnn

    目录 motivation 实验设置 实验结果 motivation 试一下faster rcnn的代码, 主要想看看backbone训练一部分好呢还是全部都训练好呢? 实验设置 Attribute ...

  7. CapstoneCS5210|CS5210低BOM成本方案CS5210|HDMI转VGA芯片方案

    Capstone最新推出的一款HDMI转VGA音视频转接线或者转换器方案芯片CS5210. 其设计的优势在于内置晶振,外围电路器件较少设计简单,芯片封装集成度较高,方案BOM成本低,相比其他方案产品更 ...

  8. Spring Boot 整合 Fisco Bcos(区块链)

    简介 FISCO BCOS是由国内企业主导研发.对外开源.安全可控的企业级金融联盟链底层平台,由金链盟开源工作组协作打造,并于2017年正式对外开源. 目前,成熟的区块链的平台不少,之所以选择FISC ...

  9. TortoiseGit使用ssh-keygen生成的私钥

    1.说明 使用TortoiseGit自带的PuTTY Key Generator工具, 把ssh-keygen生成的私钥转换为Putty使用的.ppk文件, 然后在拉取Git代码时, 加载对应的.pp ...

  10. Zookeeper基础教程(二):Zookeeper安装

    上一篇说了,一个Zookeeper集群一般认为至少需要3个节点,所以我们这里安装需要准备三台虚拟机: # 192.168.209.133 test1 # 192.168.209.134 test2 # ...