html版本号 webpack_webpack对html文件的处理

本篇文章给大家分享的是关于webpack对html文件的处理 ,步骤都很详细,有需要的朋友可以参考一下为什么去处理html文件

我们所有的方法都打包到了dist的文件夹下面,而我们的html是在自己定义的文件夹下面,如果自己手动再去一个一个src引入这些dist文件夹下的js,那么也有些太不靠谱了

所以解决办法是:

使用webpack插件:HtmlWebpackPlugin第一步:下载npm install --save-dev extract-text-webpack-plugin

第二步:webpack.config.js配置

其中HtmlWebpackPlugin的配置项有:Name类型Descriptiontitle{String}用于生成的HTML文档的标题

filename{String}要生成HTML的文件。可以指定目录

template{String}依据的模板文件

inject{Boolean|String}将js资源注入到页面哪个部位,值有:true \ ‘head’ \ ‘body’ \ false,当传递true或’body’所有JavaScript资源将被放置在正文元素的底部。’head’将脚本放置在head元素中

favicon{String}将给定的图标路径添加到输出HTML

hash{Boolean}如果true将webpack所有包含的脚本和CSS文件附加一个独特的编译哈希。这对缓存清除非常有用

chunks{?}放入你需要引入的资源模块

excludeChunks{?}不放入你某些资源模块

预期目标: 我的项目是一个多入口文件的项目,希望每一个入口页面引入对应的js模块和css

比如login页面引入login的js和css、index引入对应js和css

webpack.config.js配置如下:const path = require('path');const webpack = require('webpack')const ExtractTextPlugin = require("extract-text-webpack-plugin");const HtmlWebpackPlugin = require('html-webpack-plugin');const configs = {

entry:{ 'commom':['./src/page/common/index.js'], 'index':['./src/page/index/index.js'], 'login':['./src/page/login/index.js']

},

output:{

path:path.resolve(__dirname, 'dist'),

filename:'js/[name].js'

},

module:{

rules:[

{

test:/\.css$/,

use:ExtractTextPlugin.extract({

fallback: "style-loader",

use: "css-loader"

})

}

]

},

plugins:[ //独立通用模块

new webpack.optimize.CommonsChunkPlugin({

name : 'common',

filename : 'js/base.js'

}), //独立打包css

new ExtractTextPlugin('css/[name].css'), //对html模板进行处理,生成对应的html,引入需要的资源模块

new HtmlWebpackPlugin({

template:'./src/view/index.html',//模板文件

filename:'view/login/index.html',//目标文件

chunks:['commom','login'],//对应加载的资源

inject:true,//资源加入到底部

hash:true//加入版本号

})

]

}

module.exports= configs

然后打包结果如下

其中生成的目标文件:

为什么去处理html文件

我们所有的方法都打包到了dist的文件夹下面,而我们的html是在自己定义的文件夹下面,如果自己手动再去一个一个src引入这些dist文件夹下的js,那么也有些太不靠谱了

所以解决办法是:

使用webpack插件:HtmlWebpackPlugin第一步:下载npm install --save-dev extract-text-webpack-plugin

第二步:webpack.config.js配置

其中HtmlWebpackPlugin的配置项有:Name类型Descriptiontitle{String}用于生成的HTML文档的标题

filename{String}要生成HTML的文件。可以指定目录

template{String}依据的模板文件

inject{Boolean|String}将js资源注入到页面哪个部位,值有:true \ ‘head’ \ ‘body’ \ false,当传递true或’body’所有JavaScript资源将被放置在正文元素的底部。’head’将脚本放置在head元素中

favicon{String}将给定的图标路径添加到输出HTML

hash{Boolean}如果true将webpack所有包含的脚本和CSS文件附加一个独特的编译哈希。这对缓存清除非常有用

chunks{?}放入你需要引入的资源模块

excludeChunks{?}不放入你某些资源模块

预期目标: 我的项目是一个多入口文件的项目,希望每一个入口页面引入对应的js模块和css

比如login页面引入login的js和css、index引入对应js和css

webpack.config.js配置如下:const path = require('path');const webpack = require('webpack')const ExtractTextPlugin = require("extract-text-webpack-plugin");const HtmlWebpackPlugin = require('html-webpack-plugin');const configs = {

entry:{ 'commom':['./src/page/common/index.js'], 'index':['./src/page/index/index.js'], 'login':['./src/page/login/index.js']

},

output:{

path:path.resolve(__dirname, 'dist'),

filename:'js/[name].js'

},

module:{

rules:[

{

test:/\.css$/,

use:ExtractTextPlugin.extract({

fallback: "style-loader",

use: "css-loader"

})

}

]

},

plugins:[ //独立通用模块

new webpack.optimize.CommonsChunkPlugin({

name : 'common',

filename : 'js/base.js'

}), //独立打包css

new ExtractTextPlugin('css/[name].css'), //对html模板进行处理,生成对应的html,引入需要的资源模块

new HtmlWebpackPlugin({

template:'./src/view/index.html',//模板文件

filename:'view/login/index.html',//目标文件

chunks:['commom','login'],//对应加载的资源

inject:true,//资源加入到底部

hash:true//加入版本号

})

]

}

module.exports= configs

然后打包结果如下

其中生成的目标文件:

相关推荐:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值