详解webpack自动生成html页面

在项目中我们会不断的添加,优化代码,每次添加优化之后都需要打包进行再次上传更新。这时问题就回来了,每次打包出来js,css文件的名字都是一样的,在首页index.html的引用也不会变,这样老用户在访问这个页面时看到就会是浏览器缓存的版本,而不是最新的版本,想要看到最新版本还要进行清缓存,强制刷新,这显然是不可能的,那我们要如何解决这个问题呢?

首先有同学可能想到每次打包之后我改一下打包出来文件的名字,然后在首页index,html里面把引用代码里的文件名字也改掉就可以了,这种方法是可以的,但是每次都要改这么多,显然会很耗费时间,而且人工手动修改很可能也会带来bug。又有一位同学可能会说,不用那么麻烦,直接在上线前,在css,js资源引用的后面加一个随机数就可以了。这种方法虽然比第一种方法简单了许多,但是还是没有解决之前的问题。那么我们能不能实现每次打包完直接生成文件后面加上一个随机字符串,然后首页里的引用也一起自动变成最新打包的文件呢?答案是可以的,接下来我将讲一下利用webpack实现

webpack实现这个功能,首先要下载一个webpack的插件html-webpack-plugin

rush:bash;"> npm install html-webpack-plugin

接下来要在羡慕里新建一个文件,这个文件就是我们要生成首页文件的模板

rush:js;"> //template.js module.exports = function (templateParams) { return ( ` <Meta charset="utf-8"> <Meta http-equiv="X-UA-Compatible" content="IE=edge"> ${templateP<a href="https://www.jb51.cc/tag/ara/" target="_blank" class="keywords">ara</a>ms.htmlWebpackPlugin.options.title} <Meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no"> <Meta name="author" content=""/> <Meta name="keywords" content=""> <Meta name="description" content=""> <Meta name="HandheldFriendly" content="true"> <Meta http-equiv="content-type" content="text/html; charset=utf-8"> <Meta http-equiv="Cache-Control" content="no-transform"> <Meta http-equiv="Cache-Control" content="no-siteapp"> <Meta name="apple-mobile-web-app-capable" content="yes"> <Meta name="apple-mobile-web-app-status-bar-style" content="default"> <Meta name="format-detection" content="telephone=no">
` ) }

准备工作做好了,接下来就是进行配置了

rush:js;"> //首先引入插件 var HtmlWebpackPlugin = require('html-webpack-plugin');

界限来在配置webpack的plugins选项

rush:js;"> plugins: [ new HtmlWebpackPlugin({ //根据模板插入css/js等生成最终HTML // favicon:'./src/img/favicon.ico',//favicon路径 filename:'src/index.html',//生成的html存放路径,相对于 path template:'./src/app/template/template.js',//html模板路径 title: '升级空间运营后台',cache: true,inject:true,//允许插件修改哪些内容包括head与body hash:true,//为静态资源生成hash值 minify:{ //压缩HTML文件 removeComments:true,//移除HTML中的注释 collapseWhitespace:false //删除空白符与换行符 } }) ],

执行打包命令后,你会发现生成自动生了HTML代码,在index,html资源引用的地方会在资源后面自动生成一串hash值,这样每次更新之后用户就会自动获取最新资源了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...