当前位置: 首页 > news >正文

申请建设网站经费申请简单logo设计图片

申请建设网站经费申请,简单logo设计图片,电商网站建设与运营哦,网站建设数据库搭建hash、contenthash 和 chunkhash 是通过散列函数处理之后#xff0c;生成的一串字符#xff0c;可用于区分文件。 作用#xff1a;善用文件的哈希值#xff0c;解决浏览器缓存导致的资源未及时更新的问题 1.文件名不带哈希值 const path require(path) const HtmlWebpac… hash、contenthash 和 chunkhash 是通过散列函数处理之后生成的一串字符可用于区分文件。 作用善用文件的哈希值解决浏览器缓存导致的资源未及时更新的问题 1.文件名不带哈希值 const path require(path) const HtmlWebpackPlugin require(html-webpack-plugin) const { srcPath, distPath } require(./paths)module.exports {entry: {index: path.join(srcPath, index.js),other: path.join(srcPath, other.js)},module: {rules: []},plugins: [// 多入口 - 生成 index.htmlnew HtmlWebpackPlugin({template: path.join(srcPath, index.html),filename: index.html,// chunks 表示该页面要引用哪些 chunk 即上面的 index 和 other默认全部引用chunks: [index] // 只引用 index.js}),// 多入口 - 生成 other.htmlnew HtmlWebpackPlugin({template: path.join(srcPath, other.html),filename: other.html,chunks: [other] // 只引用 other.js})] }默认打包的情况下打包出来的文件是不带哈希值的 2. 问题所在 每一次编译后生成的文件名都一样这样会存在一个问题通过 webpack 编译生成的静态文件会被我们放置到服务器中当编译后的文件更新时由于浏览器或者服务器设置的缓存策略同名文件可能不会立刻被更新导致用户访问到的仍然是上一次的版本。 3.hash 为了解决这个问题我们通常会在文件名上加一些哈希值保证当更新文件时浏览器会重新下载资源。这里使用 hash这个占位符 const path require(path) const webpack require(webpack) const { CleanWebpackPlugin } require(clean-webpack-plugin) const webpackCommonConf require(./webpack.common.js) const { smart } require(webpack-merge) const { srcPath, distPath } require(./paths)module.exports smart(webpackCommonConf, {mode: production,output: {// filename: bundle.[contentHash:8].js, // 打包代码时加上 hash 戳filename: [name].[contentHash:8].js, // name 即多入口时 entry 的 keypath: distPath,// publicPath: http://cdn.abc.com // 修改所有静态文件 url 的前缀如 cdn 域名这里暂时用不到},module: {rules: []},plugins: [new CleanWebpackPlugin(), // 会默认清空 output.path 文件夹new webpack.DefinePlugin({// window.ENV productionENV: JSON.stringify(production)})] })打包出来如下带上hash值 当项目里没有文件发生改变时无论如何重新编译文件哈希值都不会变。但此时改变了 index.js文件增加一句输出所有文件的哈希值都会同时改变。所存在的问题 所有文件的哈希值都发生了变化导致即使只更新了一个文件都需要重新加载所有资源还是有些浪费性能的 4.chunkhash 这里是多入口的项目只改变了 index.js这个入口不希望 other.js入口的文件也被修改就可以使用占位符 chunkhash来解决另外哈希值比较长截取八位显示。 module.exports {// 部分配置省略output: {// filename: bundle.[contentHash:8].js, // 打包代码时加上 hash 戳filename: [name].[chunkhash:8].js, // name 即多入口时 entry 的 keypath: distPath,// publicPath: http://cdn.abc.com // 修改所有静态文件 url 的前缀如 cdn 域名这里暂时用不到},plugins: [], }; 可以看到同一个 chunk 打包出来的哈希值是一样的,在同一个入口中的hash是一样的 当修改了 css 文件时只有同 chunk 的 main.js 和 main.css 文件的哈希值发生了改变,css 文件是在 main.js这个 chunk 的但 other.js本身没有发生任何修改可以不用重新加载 5.contenthash 同一个 chunk 中部分文件修改导致所有文件的哈希值发生变化的问题可以使用 contenthash 来解决contenthash 只和每一个文件的内容有关内容发生变化则重新生成哈希值 module.exports {// 部分配置省略output: {filename: [name]_[contenthash:8].js,path: path.resolve(__dirname, ./dist),},plugins: [new MiniCssExtractPlugin({filename: ./[name]_[contenthash:8].css,}),], };每一个文件生成的哈希值都不一样 在index.js中多新增一行代码在打包可以看到main中csshash不会发生变化 总结 在 webpack 中有三种生成哈希值规则的方式可以用来区分文件是否修改。 hash 与整个项目有关项目里有文件修改所有文件的哈希值都会变化。chunkhash 与入口有关同一入口的文件被视为一个整体当其中一个文件修改时同入口的所有文件哈希值发生改变。contenthash 只与文件内容有关文件内容发生改变才会更改该文件的哈希值。
http://www.hkea.cn/news/14467035/

相关文章:

  • 焦作网站开发北京东直门+网站建设
  • 海口网站建设网页制作公司wordpress登陆地址修改
  • 做网站怎么建站点百度广告联盟官网下载
  • 网站开发 浏览器寻找做项目的网站
  • 网站建设怎么管理业务员游戏网站建设系统介绍
  • 金融网站建设内容制作视频的网站软件
  • 门户网站欣赏wordpress user role
  • 深圳高端网站定制锦州做网站
  • 广州微信网站开发公司网站栏目 添加 管理
  • 做网站好还是阿里巴巴好seo关键词怎么优化
  • 哪个网站做生鲜配送网站模拟课堂模式应该怎么做
  • 建设局发公告的网站中山祥云做的网站
  • 电子商务网站网络拓扑图广州番禺各镇分布图
  • 政务网站建设主机屋wordpress安装
  • 改网站js代码手机网站视频怎么下载
  • 沈阳网站建设工作项目经理岗位职责
  • 天津网站建设zymxart瑞安哪里有培训做网站的
  • 怎样用dw做网站主页wordpress 电台源码
  • 请问网上有没有比较好的网站可以做照片书的呀?要求质量比较好的!北京网站建设公司 蓝纤科技
  • 网站怎么做联系我们页面如何用ftp上传文件到网站
  • 企业所得税怎么算的seo优化工作有哪些
  • 自己做网站卖什么太原定制网站制作流程
  • 本地服务器网站建设市场营销策略分析案例
  • 正规网站建设公司多少钱wordpress截取
  • deals网站建设岚庭装饰公司口碑怎么样
  • 德清做网站贵州建设项目门户网站
  • 不花钱的网站怎么做个人作品网站怎么做
  • 酒店类网站开发的策略ui网页设计实习周报
  • 做外贸比较好得网站整个网站全部乱码
  • 建设保护动物网站的素材工信部备案网站