webpack除了编译打包js外,还可以编译处理CSS,本篇文章主要讲述如何使用style-loader和css-loader对css打包,主要从以下几点进行讲述:
1、css的引入分为三种情况:
标签,在标签内可以写css样式
标签引入css文件2、在js中导入css样式有:
1、 style-loader
标签,标签里的内容就是CSS内容。npm install style-loader --save-dev
2、css-loader
import
一个css文件,会将css文件当成一个模块引入到js文件中。npm install css-loader --save-dev
3、实例
npm init
html{
background: red;
}
import './css/base.css';
// 引入node的path模块
var path = require('path');
module.exports = {
entry: {
app: "./src/app.js" // 要打包的入口文件
},
output: {
path: path.resolve(__dirname, "dist"), // 使用绝对路径,dist目录
filename: "[name].bundle.js" // 或./dist/[name].[hash:5].js
},
module: {
rules: [ // 定义css规则
{
test: /\.css$/, // 正则匹配要识别的css
use: [
{
loader: 'style-loader' // 使用style-loader进行处理,位置必须在css-loader前面
},
{
loader: 'css-loader' // 使用css-loader进行处理
}
]
//use:['style-loader','css-loader'] // 此处也可以这样写
}
]
}
}
注:上面是webpack2的写法,下面是webpack1的写法,webpack1建议抛弃。
module: {
loaders: [
{
test: /\.css$/,
loader: 'style-loaer!css-loader'
}
]
}
// module
exports.push([module.i, "html{\r\n background: red;\r\n}", ""]);
4、测试打包文件
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Titletitle>
head>
<body>
<script src="./dist/app.bundle.js">script>
body>
html>
1、 作用
使用style-loader会将js中的css样式打包成标签,而使用style-loader/url则会将js中引入的css文件样式打包成一个css文件,并通过
标签引入。
2、 安装file-loader
引入文件则需要使用file-loader,npm install file-loader --save-dev
3、 配置webpack.config.js文件
// 引入node的path模块
var path = require('path');
module.exports = {
entry: {
app: "./src/app.js" // 要打包的入口文件
},
output: {
path: path.resolve(__dirname, "dist"), // 使用绝对路径,dist目录
publicPath: './dist/',// todo 指定打包后页面加载的文件路径
filename: "[name].bundle.js" // 或./dist/[name].[hash:5].js
},
module: {
rules: [ // 定义css规则
{
test: /\.css$/, // 正则匹配要识别的scc
use: [
{
loader: 'style-loader/url' // 使用style-loader进行处理,位置必须在css-loader前面
},
{
loader: 'file-loader' // 使用css-loader进行处理
}
]
// use:['style-loader','css-loader']
}
]
}
}
4、打包测试
执行打包命令webpack
,会在dist目录下生成一个css文件,文件内容就是base.css文件中的样式。
运行index.html,在浏览器上查看源代码,会发现此时css样式是用引入的:
5、 注意
使用style-loader会将css打包成css文件,并将css文件通过标签进行引入,当app.js中
import
两个css文件时,执行打包时会在dist目录下生成两个css文件,然后html页面也会引入两个css文件。
例如:
import './css/base.css';
import './css/common.css';
webpack
1、作用
使用style-loader/useable,会使导入的css模块能够使用use()和unuse()方法,方便我们进行操作。
2、配置webpack.config.js文件
rules: [ // 定义css规则
{
test: /\.css$/, // 正则匹配要识别的css
use: [
{
loader: 'style-loader/useable' // 使用userable
},
{
loader: 'css-loader'
}
}
]
3、在app.js中引入base.css文件,并编写测试代码
import Base from './css/base.css';
var flag = false;
setInterval(function () {
if (flag) {
Base.use();
} else {
Base.unuse();
}
flag = !flag;
}, 500);
4、打包测试
执行打包命令webpack
,运行index.html会发现当前css样式会不断的加载和移除。
对style-loader进行操作,可以配置options属性,options属性常用的有:
1、attrs
标签设置属性,attrs是个对象,内容以键值对形式呈现。use: [
{
loader: 'style-loader',
options:{
attrs:{
id:"index", // 创建id为index,name为index的
name:"index"
},
insertAt :"top", // 插入到id为app的dom元素下
singleton:true // 是否只使用一个style,会将页面上的style标签合成一个
}
},
{
loader: 'css-loader'
}
]
2、insertAt和insertInto
标签的首行 use: [
{
loader: 'style-loader',
options:{
insertAt :"top", // 插入到id为app的dom元素下
singleton:true // 是否只使用一个style,会将页面上的style标签合成一个
}
},
{
loader: 'css-loader'
}
]
测试结果
2)insertAt属性设置为bottom,会将css样式插入到
标签的末行
配置webpack.config.js
use: [
{
loader: 'style-loader',
options:{
insertAt :"bottom", // 插入到id为app的dom元素下
singleton:true // 是否只使用一个style,会将页面上的style标签合成一个
}
},
{
loader: 'css-loader'
}
]
测试结果
3)使用insertInto将style样式插入到id为app的元素内
配置webpack.config.js
use: [
{
loader: 'style-loader',
options:{
insertInto:"#app", // 插入到id为app的dom元素下
singleton:true // 是否只使用一个style,会将页面上的style标签合成一个
}
},
{
loader: 'css-loader'
}
]
标签,会将页面上的
标签合成一个。true
或者false
use: [
{
loader: 'style-loader',
options:{
singleton:true // 是否只使用一个style,会将页面上的style标签合成一个
}
},
{
loader: 'css-loader'
}
]
5、transform
use: [
{
loader: 'style-loader',
options:{
// 转化,浏览器环境下,插入页面前,通过这个js能够获取css,并做一些操作
transform:"css.transform.js"
}
},
{
loader: 'css-loader'
}
]
// 对css进行形变
module.exports = function (css) {
console.log(css);
console.log(window.innerWidth);
// 如果什么都不做,直接return css;
if (window.innerWidth >= 768) {
return css.replace("red","blue");
}else {
return css.replace("red","orange");
}
// 在每个class样式前,添加color属性
/* const transformed = css.replace(/}/g, 'color: blue;\n}')
return transformed;*/
}
对css-loader进行操作,可以配置options属性,options属性常用的有:
1、importLoader(@import)
2、minimize(是否压缩)
use: [
{
loader: 'style-loader',
},
{
loader: 'css-loader',
options: {
minimize: true // 对style样式进行压缩
}
}
]
use: [
{
loader: 'style-loader',
},
{
loader: 'css-loader',
options: {
modules:true // 启用css模块化调用
}
}
]
import Base from './css/base.css';
import './css/common.css';
var app = document.getElementById("app");
app.innerHTML = `class="${Base.box}">div>`;
- 在base.css中添加代码
.box{
composes: bigBox from './common.css'; // 模块化导入common.js中的bigBox
width: 300px;
height:300px;
border-radius: 4px;
}
- 在common.js中添加代码
.bigBox{
background: blue;
}
执行打包命令
webpack
修改生成的class的名称
通过localIdentName来配置修改生成的class的名称,[path][name]
是当前路径名称,[local]
是当前class名称,[hash:base64:5]
指5位的base54编码的hash值。
use: [
{
loader: 'style-loader',
},
{
loader: 'css-loader',
options: {
modules:true, // 启用css模块化调用
localIdentName:"[path][name]_[local]_[hash:base64:5]" // 修改生成的class的名称
}
}
]
如下图所示:
参考:
https://www.npmjs.com/package/css-loader
http://www.css88.com/doc/webpack2/loaders/css-loader/
https://yq.aliyun.com/articles/281033