webpack对html文件的处理


本文摘自PHP中文网,作者不言,侵删。

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

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

所以解决办法是:

使用webpack插件:HtmlWebpackPlugin

  • 第一步:下载

1

npm install --save-dev extract-text-webpack-plugin

第二步:webpack.config.js配置

其中HtmlWebpackPlugin的配置项有:

Name类型Description
title{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配置如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

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类型Description
title{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配置如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

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

然后打包结果如下
这里写图片描述

其中生成的目标文件:
这里写图片描述

相关推荐:

在webpack中使用ECharts详解

Node.js、jade生成静态html文件实例

webpack的插件详解

以上就是webpack对html文件的处理的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

html中sub标签是什么?关于html sub标签的定义和使用方法介绍

html video方法怎么用

html表单边框怎么加颜色?html form标签的边框颜色实例

h5和html的区别是什么

html怎么注释单行

在html中iframe与frame有哪些区别

怎么给html设置背景色

html引入外部javascript是什么属性

html如何调用js函数

html搜索框怎么设置?html搜索框input标签的使用方法实例

更多相关阅读请进入《webpack》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...