使用webpack3.0配置webpack-dev-server教程


Posted in Javascript onMay 29, 2018

最近正在研究webpack,听说webpack可以自己搭建一个小型的服务器(使用过vue-cli的朋友应该都见识到过),所以迫不及待的想要尝试一下。不过,在实际操作中发现,用webpack搭建服务器仍有不少坑,一方面是由于自己对文档的不熟悉,不了解webpack-dev-server的运作模式;另一方面,在翻阅了不少博客和文章后,发现不少配置实际上都跑不起来(有可能是版本的原因,也有可能是我自己配置的原因)。所以我打算用webpack3.0把dev-server跑起来给大家演示一遍,顺便把一些配置和原理给大家讲清楚,这样就省的绕弯路了。

这里我就默认大家都已经安装了webpack以及自己需要使用的loader和plugins,由于webpack-dev-server是个独立的npm包,所以我们需要在npm下安装它: 

npm install webpack-dev-server --save-dev

之后我们就可以在webpack.config.js中进行配置:

const path = require("path");
module.exports = {
   entyr:{
      ....... //设置入口文件
   },
   output:{
      ....... //设置出口文件
   },
   module:{
      ....... //配置loader,注意使用rules而不是loaders
   },
   plugins:[
      ....... //注意是数组
   ],
   devServer:{
      //我们在这里对webpack-dev-server进行配置
   }        
}

devServer中常用的配置对象属性如下:

1. contentBase:"./" // 本地服务器在哪个目录搭建页面,一般我们在当前目录即可;

2. historyApiFallback:true // 当我们搭建spa应用时非常有用,它使用的是HTML5 History Api,任意的跳转或404响应可以指向 index.html页面;

3. inline:true // 用来支持dev-server自动刷新的配置,webpack有两种模式支持自动刷新,一种是iframe模式,一种是inline模式;使用iframe模式是不需要在devServer进行配置的,只需使用特定的URL格式访问即可;不过我们一般还是常用inline模式,在devServer中对inline设置为true后,当我们启动webpack-dev-server时仍要需要配置inline才能生效,这一点我们之后再说;

4. hot:true // 启动webpack热模块替换特性,这里也是坑最多的地方,不少博客都将hot设置了true,我们姑且也设置为true,之后再看;

5. port:端口号(默认8080) // 这就不用我多说了吧;

事实上大概常用的配置也就这样,为了方便,我们在packjson中对webpack-dev-server的的启动进行一下设置:

"scripts": {
  ......
  ......
  "start":"webpack-dev-server --inline"
 },

别忘了在devServer中设置inline:true后这里也要设置一下!

这时我们打包后再运行服务器后应该发现index.html页面已经展示了,打包好后的js文件虽然出现在了src上,但并没有显示,打开控制台会发现如下报错:

使用webpack3.0配置webpack-dev-server教程

控制台显示:Hot Module Replacement is disabled;

奇怪?我们之前不是在devServer中设置了hot为true了吗?事实上,虽然不知道为什么,但是目前来说hot这个属性已经没有用了,使用热模块的话我们需要用到一个叫webpack.HotModuleReplacementPlugin的插件。所以我们的webpack.config.js需要加上这些:

const path = require("path");
const webpack = requier ("webpack");

module.exports = {
   entyr:{
      ....... //设置入口文件
   },
   output:{
      ....... //设置出口文件
   },
   module:{
      ....... //配置loader,注意使用rules而不是loaders
   },
   plugins:[
     new webpack.HotModuleReplacementPlugin()
      ....... //注意是数组
   ],
   devServer:{
     contentBase: "./", 
   historyApiFallback:true,
   inline:true,
   hot:true
   }        
}

这时我们再在bash上运行npm run start后发现服务器就搭建完成了!

使用webpack3.0配置webpack-dev-server教程

另外,还有一点值得注意的就是,webpack-dev-server所使用的bundle.js文件并不是webpack.config.js中output打包生成的bundle.js,而是使用webpack-dev-server自己打包生成的,这个文件不存在与output或其他路径中,而是存到了内存中,事实上webpack-dev-server所使用的那个bundle.js我们是看不到的!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js 方法实现返回多个数据的代码
Apr 30 Javascript
JS.elementGetStyle(element, style)应用示例
Sep 24 Javascript
json字符串之间的相互转换示例代码
Aug 21 Javascript
javascript检测是否联网的实现代码
Sep 28 Javascript
Jquery日期选择datepicker插件用法实例分析
Jun 08 Javascript
AngularJS ng-bind 指令简单实现
Jul 30 Javascript
jQuery菜单实例(全选,反选,取消)
Aug 28 jQuery
node.js基于express使用websocket的方法
Nov 09 Javascript
vue2.0 实现富文本编辑器功能
May 26 Javascript
JS中实现浅拷贝和深拷贝的代码详解
Jun 05 Javascript
node-red File读取好保存实例讲解
Sep 11 Javascript
react实现同页面三级跳转路由布局
Sep 26 Javascript
vuejs 切换导航条高亮(路由菜单高亮)的方法示例
May 29 #Javascript
微信小程序6位或多位验证码密码输入框功能的实现代码
May 29 #Javascript
Vue 全局loading组件实例详解
May 29 #Javascript
详解vue-cli 本地开发mock数据使用方法
May 29 #Javascript
详解vue-cli项目中怎么使用mock数据
May 29 #Javascript
js统计页面上每个标签的数量实例代码
May 29 #Javascript
浅谈React的最大亮点之虚拟DOM
May 29 #Javascript
You might like
PHP+JS+rsa数据加密传输实现代码
2011/03/23 PHP
php权重计算方法代码分享
2014/01/09 PHP
PHP读取、解析eml文件及生成网页的方法示例
2017/09/04 PHP
JavaScript中的类继承
2010/11/25 Javascript
JavaScript字符串对象的concat方法实例(用于连接两个或多个字符串)
2014/10/16 Javascript
JQuery控制Radio选中方法分析
2015/05/29 Javascript
js实时获取并显示当前时间的方法
2015/07/31 Javascript
分享Javascript实用方法二
2015/12/13 Javascript
JS实现设置ff与ie元素绝对位置的方法
2016/03/08 Javascript
NodeJS模块与ES6模块系统语法及注意点详解
2019/01/04 NodeJs
微信小程序实现的自定义分享功能示例
2019/02/12 Javascript
微信小程序:数据存储、传值、取值详解
2019/05/07 Javascript
js如何获取访问IP、地区、当前操作浏览器
2019/07/23 Javascript
vue组件创建的三种方式小结
2020/02/03 Javascript
Vue的双向数据绑定实现原理解析
2020/02/17 Javascript
用python + openpyxl处理excel2007文档思路以及心得
2014/07/14 Python
Python实现将SQLite中的数据直接输出为CVS的方法示例
2017/07/13 Python
python中装饰器级连的使用方法示例
2017/09/29 Python
python json.loads兼容单引号数据的方法
2018/12/19 Python
opencv与numpy的图像基本操作
2019/03/08 Python
解决在pycharm运行代码,调用CMD窗口的命令运行显示乱码问题
2019/08/23 Python
Python数组拼接np.concatenate实现过程
2020/04/18 Python
零基础小白多久能学会python
2020/06/22 Python
CSS3实现多重边框的方法总结
2016/05/31 HTML / CSS
HTML5中语义化 b 和 i 标签
2008/10/17 HTML / CSS
英国最大的手表网站:The Watch Hut
2017/03/31 全球购物
酒店员工职业生涯规划
2014/02/25 职场文书
电焊工岗位职责
2014/03/06 职场文书
工商行政管理专业求职书
2014/05/23 职场文书
幼儿园园长新年寄语2015
2014/12/08 职场文书
旷课检讨书范文
2015/01/27 职场文书
搞笑老公保证书
2015/02/26 职场文书
教育教学读书笔记
2015/07/02 职场文书
中学教代会开幕词
2016/03/04 职场文书
Java基础之详解HashSet的使用方法
2021/06/30 Java/Android
Python学习之时间包使用教程详解
2022/03/21 Python