webpack-css單獨打包配置


一、extract-text-webpack-plugin 使用方法

這個操作很簡單的,只需要一個插件就好了,就是extract-text-webpack-plugin

  1. 安裝extract-text-webpack-plugin

npm install extract-text-webpack-plugin --save-dev
2. 配置文件添加對應配置

首先require一下

var ExtractTextPlugin = require("extract-text-webpack-plugin");
plugins里面添加

new ExtractTextPlugin("styles.css"),
實例:

plugins: [
new webpack.optimize.CommonsChunkPlugin('common.js'),
new ExtractTextPlugin("styles.css"),
],
modules里面對css的處理修改為

{
test: /.css$/,
loader: ExtractTextPlugin.extract("style-loader","css-loader")
},
千萬不要重復了,不然會不起作用的

我這里如下:

module: {
loaders: [
{
test: /.css$/,
loader: ExtractTextPlugin.extract("style-loader","css-loader")
},
{
test: /.scss$/,
loader: "style!css!sass"
},
{
test: /.less$/,
loader: "style!css!less"
},
]
},
3. 在引入文件里面添加需要的css,【舉例如下】

require('../less/app.less');
require('./bower_components/bootstrap-select/dist/css/bootstrap-select.min.css');
require('./bower_components/fancybox/source/jquery.fancybox.css');
二、如何把CSS打包成一個文件, 和 把CSS打包成多個文件

打包一個文件,只需要常規的在入口的js文件引用 css文件即可, 打包成多個CSS文件,可以設置多個CSS入口,讓webpack用 loader去打包。 和分割單獨打包js文件一樣。下面有兩個例子。【例子來源】
// 使用webpack 打包單獨的postcss語法的css文件
/* webpack.config.js /
var precss = require('precss');
var cssnext = require('cssnext');
var autoprefixer = require('autoprefixer');
var cssnano = require('cssnano');
var Ex = require('extract-text-webpack-plugin');
module.exports = {
entry: './【path】/index.js',
/
index.js 里 require('./【name】.css');就好 我在看看文檔是不是直接不用引入js文件 /
output: {
filename: 'index.js'
},
module: {
loaders: [{
test: /.css$/,
loader: Ex.extract('style-loader', 'css-loader!postcss-loader') /
這里的寫法注意下 */
}]
},
postcss: function() {
return [autoprefixer, cssnext, precss, cssnano]
},
plugins: [
new Ex("【name】.css")
]
}
//////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////////
// 使用webpack 打包單獨的多個postcss語法的css文件
var precss = require('precss');
var cssnext = require('cssnext');
var autoprefixer = require('autoprefixer');
var cssnano = require('cssnano');
var Ex = require('extract-text-webpack-plugin');
var webpack = require('webpack');

module.exports = {
entry: {
ac1: './src/actother.css',
ac2: './src/index.css'
},
output: {
filename: "[name].css"
},
module: {
loaders: [{
test: /.css$/,
loader: Ex.extract('style-loader', 'css-loader!postcss-loader')
}]
},
postcss: function() {
return [autoprefixer, precss, cssnano, cssnext]
},
plugins: [
new Ex('[name].css')
]
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM