websocket4.0+typescript 实现热更新的方法


Posted in Javascript onAugust 14, 2019

最近搞了一个webpack4+typescript的开发环境,折腾了很久现在记录一下。。。。

本身环境比较好搞,但是热更新是个麻烦事儿

本环境是基于webpack-dev-server搭建的

output: {
  publicPath: '/dist',
  path: path.resolve(__dirname, 'dist'),
  filename: 'ljax.bundle.js',
  hotUpdateChunkFilename: 'hot/hot-update.js',
  hotUpdateMainFilename: 'hot/hot-update.json'
 },

publicPath是必须的字段,不添加HRM就没有效果

在热更新的时候会出现很多hot-update.js和hot-update.json的细碎文件

使用hotUpdateChunkFilename和hotUpdateMainFilename指定他们只生成一个文件,目前没有找到不生成这两个文件的办法,如果哪位大佬知道的话请告知。

plugins: [
  new HtmlWebpackPlugin({
   title: '模块热替换',
   template: './public/index.html'
  }),
  new webpack.HotModuleReplacementPlugin(),
  // 启动输出清理
  new FriendlyErrorsWebpackPlugin({
   compilationSuccessInfo: {
    messages: [`You application is running here ${HTTPS ? 'https' : 'http'}://${HOST}:${PORT}`],
    // notes: ['Some additional notes to be displayed upon successful compilation'],
    clearConsole: true
   },
  })
 ],

HotModuleReplacementPlugin是热更新必不可少的插件

contentBase: __dirname,
  quiet: true,
  compress: true,
  port: PORT,
  host: HOST,
  https: HTTPS,
  // hot: true,
  // hotOnly: true,
  // inline: true,
  open: true,
  overlay: true,
  openPage: './dist/index.html'

最坑的地方来了,我一开始是加上可hot和hotOnly字段的,但是不管是两个都加还是单独使用任何一个,HRM都没有效果。。。。

最后发现两个都不实用就可以。。。。。妈耶,我还是从官网看的这个配置。

到现在也不是很了解是怎么回事。。

最后,贴一下完整的配置吧

webpack.config.js

const path = require('path')
const FriendlyErrorsWebpackPlugin = require('friendly-errors-webpack-plugin')
const webpack = require('webpack')
const HtmlWebpackPlugin = require('html-webpack-plugin')

const HOST = 'localhost'
const PORT = 8080
const HTTPS = false

module.exports = {
 mode: 'development',

 context: __dirname,

 entry: {
  app: './src/index.ts'
 },

 output: {
  publicPath: '/dist',
  path: path.resolve(__dirname, 'dist'),
  filename: 'ljax.bundle.js',
  hotUpdateChunkFilename: 'hot/hot-update.js',
  hotUpdateMainFilename: 'hot/hot-update.json'
 },

 module: {
  rules: [
   { test: /\.ts/, use: 'ts-loader', exclude: /node_modules/ }
  ]
 },

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

 plugins: [
  new HtmlWebpackPlugin({
   title: '模块热替换',
   template: './public/index.html'
  }),
  new webpack.HotModuleReplacementPlugin(),
  // 启动输出清理
  new FriendlyErrorsWebpackPlugin({
   compilationSuccessInfo: {
    messages: [`You application is running here ${HTTPS ? 'https' : 'http'}://${HOST}:${PORT}`],
    // notes: ['Some additional notes to be displayed upon successful compilation'],
    clearConsole: true
   },
  })
 ],

 devServer: {
  contentBase: __dirname,
  quiet: true,
  compress: true,
  port: PORT,
  host: HOST,
  https: HTTPS,
  // hot: true,
  // hotOnly: true,
  // inline: true,
  open: true,
  overlay: true,
  openPage: './dist/index.html'
 }
}

package.json

{
 "name": "ljax",
 "version": "1.0.0",
 "description": "",
 "main": "index.js",
 "scripts": {
  "test": "echo \"Error: no test specified\" && exit 1",
  "watch": "webpack -w",
  "dev-server": "webpack-dev-server",
  "serve": "start yarn dev-server && yarn watch"
 },
 "author": "",
 "license": "ISC",
 "dependencies": {
  "friendly-errors-webpack-plugin": "^1.7.0",
  "html-webpack-plugin": "^3.2.0",
  "ts-loader": "^6.0.4",
  "typescript": "^3.5.3",
  "webpack": "^4.39.1",
  "webpack-dev-server": "^3.7.2"
 },
 "devDependencies": {
  "webpack-cli": "^3.3.6"
 }
}

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

Javascript 相关文章推荐
jquery Tab效果和动态加载的简单实例
Dec 11 Javascript
JS取request值以及自动执行使用示例
Feb 24 Javascript
node.js中的fs.utimesSync方法使用说明
Dec 15 Javascript
js实现文本框支持加减运算的方法
Aug 19 Javascript
AngularJS入门教程之AngularJS模型
Apr 18 Javascript
详解JavaScript跨域总结与解决办法
Oct 31 Javascript
ES6新特性五:Set与Map的数据结构实例分析
Apr 21 Javascript
在vue项目中引入高德地图及其UI组件的方法
Sep 04 Javascript
angular 表单验证器验证的同时限制输入的实现
Apr 11 Javascript
使用layer弹窗提交表单时判断表单是否输入为空的例子
Sep 26 Javascript
vue 组件销毁并重置的实现
Jan 13 Javascript
如何在postman测试用例中实现断言过程解析
Jul 09 Javascript
利用JavaScript的Map提升性能的方法详解
Aug 14 #Javascript
微信小程序 调用远程接口 给全局数组赋值代码实例
Aug 13 #Javascript
vue源码nextTick使用及原理解析
Aug 13 #Javascript
封装微信小程序http拦截器过程解析
Aug 13 #Javascript
Vue中通过Vue.extend动态创建实例的方法
Aug 13 #Javascript
微信小程序封装分享与分销功能过程解析
Aug 13 #Javascript
node删除、复制文件或文件夹示例代码
Aug 13 #Javascript
You might like
PHP iconv 解决utf-8和gb2312编码转换问题
2010/04/12 PHP
php实现数组筛选奇数和偶数示例
2014/04/11 PHP
php实现用于删除整个目录的递归函数
2015/03/16 PHP
TNC vs RR BO3 第一场 2.14
2021/03/10 DOTA
基于jquery可配置循环左右滚动例子
2011/09/09 Javascript
jquery 单引号和双引号的区别及使用注意
2013/07/31 Javascript
jQuery语法小结(超实用)
2015/12/31 Javascript
jQuery事件绑定on()与弹窗实现代码
2016/04/28 Javascript
JavaScript原生编写《飞机大战坦克》游戏完整实例
2017/01/04 Javascript
5种JavaScript脚本加载的方式
2017/01/16 Javascript
图片上传之FileAPI与NodeJs
2017/01/24 NodeJs
React入门教程之Hello World以及环境搭建详解
2017/07/11 Javascript
详解利用 Vue.js 实现前后端分离的RBAC角色权限管理
2017/09/15 Javascript
Vue 换肤的示例实践
2018/01/23 Javascript
Vue 创建组件的两种方法小结(必看)
2018/02/23 Javascript
layui table设置前台过滤转义等方法
2018/08/17 Javascript
使用vue脚手架(vue-cli)搭建一个项目详解
2019/05/09 Javascript
简单了解JavaScript中的执行上下文和堆栈
2019/06/24 Javascript
python通过wxPython打开一个音频文件并播放的方法
2015/03/25 Python
浅谈Python中copy()方法的使用
2015/05/21 Python
浅谈python中的正则表达式(re模块)
2017/10/17 Python
python脚本作为Windows服务启动代码详解
2018/02/11 Python
python如何读写csv数据
2018/03/21 Python
Python应用库大全总结
2018/05/30 Python
Python实现查找最小的k个数示例【两种解法】
2019/01/08 Python
PyQt Qt Designer工具的布局管理详解
2019/08/07 Python
Python2比较当前图片跟图库哪个图片相似的方法示例
2019/09/28 Python
Pytorch - TORCH.NN.INIT 参数初始化的操作
2021/02/27 Python
PAUL HEWITT手表美国站:德国北部时尚生活配饰品牌,船锚元素
2017/11/18 全球购物
小学校园广播稿(3篇)
2014/09/19 职场文书
临床医学生职业规划书范文
2014/10/25 职场文书
党的群众路线调研报告
2014/11/03 职场文书
开除通知书范本
2015/04/25 职场文书
党小组评议意见
2015/06/02 职场文书
JavaScript如何利用Promise控制并发请求个数
2021/05/14 Javascript
MongoDB使用场景总结
2022/02/24 MongoDB