webpack学习extract-text-webpack-plugin 单独打包css

webpack单独打包css

1.首先安装extract-text-webpack-plugin

2.在webpack.config.js里面引入
const ExtractPlugin = require(‘extract-text-webpack-plugin’)
3.配置 plugins: [
new HtmlWebpackPlugin(
{
title:‘ToDo’ //自动生成的index.html设置title
}
),
new VueLoaderPlugin(),
new ExtractPlugin(‘css/main.css’) //设置打包生成的css文件目录
],`
4.
{
test: /.styl/,
use: ExtractPlugin.extract({
fallback: ‘style-loader’,// 如果提取失败,就使用style-loader加载到页面
use: [‘css-loader’, ‘stylus-loader’]
})
}
//以styl结尾的css文件 使用插件

使用单独打包 css文件使用link`

<link href="css/main.css" rel="stylesheet"></head>代码片
   {
        test: /\.styl$/,
        // !!!这是打包到 <style></style> 中去了.
        loader: ['style-loader', 'css-loader', 'stylus-loader']
    }

fallback:意思是,如果打包单个文件失败了,就还是利用 style-loader 写入 HTML 文件的 中.
extract-text-webpack-plugin目前版本不支持webpack4。
解决方案: 使用extract-text-webpack-plugin的最新的beta版 npm install extract-text-webpack-plugin@next

要使用 `extract-text-webpack-plugin` 插件,你需要先安装它。在安装之前,确保你已经安装了 Node.js 和 npm。 安装 `extract-text-webpack-plugin` 的命令如下: ``` npm install --save-dev extract-text-webpack-plugin ``` 安装完成后,在 webpack 的配置文件中引入插件: ```javascript const ExtractTextPlugin = require('extract-text-webpack-plugin'); ``` 然后在 `module.rules` 中配置插件的规则: ```javascript module.exports = { // ...其它配置项... module: { rules: [ // ...其它规则... { test: /\.css$/, use: ExtractTextPlugin.extract({ fallback: 'style-loader', use: ['css-loader'] }) } ] }, plugins: [ new ExtractTextPlugin('styles.css') ] }; ``` 在上面的代码中,我们将 `ExtractTextPlugin` 实例化并传入一个输出文件名,然后在 `module.rules` 中的 CSS 规则中使用 `ExtractTextPlugin.extract()` 方法来提取 CSS单独文件中。注意,我们同时使用了 `style-loader` 和 `css-loader`,这是因为 `ExtractTextPlugin.extract()` 方法要求至少有一个 loader 是非提取 loader(即不会将文件输出到文件系统中),这里我们使用了 `style-loader` 来将 CSS 插入到 HTML 文档中。 以上代码中,我们还需要在 webpack 配置文件的 `plugins` 中添加 `new ExtractTextPlugin('styles.css')`,这个插件将会在构建时将 CSS 提取到指定的输出文件中。 最后,运行 webpack 构建命令,就能够将 CSS 提取到单独的文件中了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值