您好,欢迎来到曼谷因美食网。
搜索
您的当前位置:首页webpack对html文件的处理

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

    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配置如下:

    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

    然后打包结果如下

    其中生成的目标文件:

    Copyright © 2019- manguyin.com 版权所有

    违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

    本站由北京市万商天勤律师事务所王兴未律师提供法律服务