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

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

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

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Webpack的配置文件通常命名为`webpack.config.js`,它需要导出一个包含Webpack配置信息的JavaScript对象。以下是一个基本的Webpack配置文件示例: ```javascript const path = require('path'); module.exports = { // 入口文件 entry: './src/index.js', // 输出文件 output: { filename: 'bundle.js', path: path.resolve(__dirname, 'dist') }, // 模块处理规则 module: { rules: [ // 处理.js文件 { test: /\.js$/, exclude: /node_modules/, use: { loader: 'babel-loader', options: { presets: ['@babel/preset-env'] } } } ] } }; ``` 上述示例中,我们定义了一个入口文件`src/index.js`,一个输出文件`dist/bundle.js`,以及一个用于处理.js文件的规则,它使用了babel-loader和@babel/preset-env。在实际使用中,你可能需要根据具体情况进行调整。 ### 回答2: webpack的配置文件是一个名为webpack.config.js的JavaScript文件,用于指定webpack的打包规则和插件配置。通过对webpack.config.js的配置,可以实现对项目的模块打包、代码转译、优化等操作。 在webpack.config.js中,需要导出一个配置对象,其中包含一些常用的配置项。以下是一些常见的配置项: entry:指定项目的入口文件,用于指定webpack从哪个文件开始打包。 output:用于配置打包后的输出文件的名称和路径。 module:用于配置不同类型模块的加载器。比如,可以使用babel-loader来处理JS文件的转译,使用css-loader和style-loader来处理CSS文件的导入和样式注入等。 plugins:用于配置webpack的插件。比如,可以使用HtmlWebpackPlugin来自动生成HTML文件,使用UglifyJsPlugin来压缩JS代码等。 resolve:用于配置模块路径的解析规则。比如,可以指定webpack优先使用哪种文件扩展名来匹配模块。 devServer:用于配置开发服务器的行为。比如,可以指定服务器的端口号、代理配置、是否启用热模块替换等。 以上只是一些常用的配置项,webpack的配置文件还有很多其他的选项可以根据项目需求进行配置。 要使用webpack的配置文件,只需在命令行中运行webpack命令,并将配置文件作为参数传递,例如:webpack --config webpack.config.js。 ### 回答3: Webpack的配置文件是用于定义和配置Webpack工具的文件,它通常以webpack.config.js命名,并位于项目根目录下。Webpack是一个模块打包工具,可以将各种类型的资源文件进行打包和优化,使其能够在浏览器中运行。 Webpack的配置文件主要包含一些配置项和规则,用于定义打包规则如何处理不同类型的文件,以及如何优化打包输出结果。 在配置文件中,我们可以定义入口文件(entry)和输出文件(output),用于指定打包的入口和输出的文件路径。可以使用loader来对各种类型的资源文件进行处理,如ES6语法转换、CSS预处理、图片压缩等。还可以使用插件(plugins)来扩展Webpack的功能,如提取CSS文件、自动生成HTML文件等。 配置文件中的其他配置项还包括模式(mode),用于指定打包的模式,如开发模式(development)或生产模式(production);devServer配置用于配置开发服务器,以便在开发过程中实时预览项目;resolve配置用于配置模块解析规则,如设置别名、指定模块的查找路径等。 在配置文件中,我们可以编写一些自定义逻辑来实现特定的需求,例如根据环境变量配置不同的打包策略,动态生成入口文件等。 总之,Webpack的配置文件是一个用于定义和配置Webpack工具的文件,通过对配置项、规则、插件等进行编写和配置,可以实现各种资源的打包和优化,使项目在浏览器中能够正常运行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值