参考
编译CSS
处理CSS
需要借助webpack的style-loader
,css-loader
,postcss-loader
以及autoprefixer
;
-
style-loader
创建style
标签,并将模块的导出的样式添加到 标签中;
让CSS
在页面生效,让样式变成页面中的style
标签;
加载CSS
文件,包装成webpack
能够识别的CSS
,但不能让CSS
文件产生效果;
解析CSS
文件后,使用import
加载,并且返回 CSS
代码;
使用 PostCSS 加载和转译CSS/SSS
文件;
帮助webpack
加载css
,但于css-loader
的区别在于:
css-loader
: 纯加载,将样式转换成字符串
postcss
加载样式的同时还要进行样式的解析,便于postcss
添加前缀
postcss-loader
不能单独使用,需要autoprefixer
的帮助来完成前缀的添加操作
使用;
-
autoprefixer
postcss-loader
需要借助autoprefixer
插件来根据浏览器的兼容性为CSS3
的属性添加前缀;
根据浏览器的兼容来帮助选择性添加兼容前缀,因为autoprefixer
中内置了一个浏览器兼容表,某个样式大于5%(可修改),就会兼容
配置
1.创建本地项目webpack-demo
mkdir webpack-demo
cd webpack-demo
2.在webpack-demo
的根目录下创建package.json
文件
npm init -y
- 安装
webpack
依赖包
npm i webpack webpack-cli webpack-dev-server --save-dev
模块说明:
-
webpack
webpack
核心 -
webpack-cli
webpack
的脚手架(启动器) -
webpack-dev-server
开发环境下用于实时加载依赖
4.修改package.json
文件的scripts
属性值,进行打包资源的配置
"scripts": {
"dev": "webpack-dev-server --open --mode development",
"build": "webpack --mode production"
},
5.安装需要的loader
和插件
npm i style-loader css-loader postcss-loader autoprefixer --save-dev
6.配置编译CSS的loader
const path = require('path');
// 显示进程的完成进度
var ProgressBarPlugin = require('progress-bar-webpack-plugin');
// 设置进度字体颜色
const chalk = require('chalk');
// 输出html
const HtmlWebpackPlugin = require('html-webpack-plugin');
module.exports = {
mode: 'development',
entry: {
app: './src/app.js'
},
output: {
path: path.resolve(__dirname, '../dist'),
filename: '[name].[hash].js'
},
module: {
rules: [
{
test: /\.jsx?$/,
use: [
{loader: 'babel-loader'}
]
},
{
test: /\.css$/,
use: [
{
loader: 'style-loader'
},
{
loader: 'css-loader'
},
{
loader: 'postcss-loader'
}
]
}
]
},
plugins: [
new HtmlWebpackPlugin({
title: 'Webpack Study Demo',
filename: 'index.html',//指定生成的HTML文件名
template: path.join(__dirname, '../public/index.html') // 指定模板路径
}),
new ProgressBarPlugin({
format: chalk.green('Progressing') + '[:bar]' + chalk.green(':percent') + '(:elapsed seconds)',
clear: false
})
]
}
7.创建postcss.config.js
,进行配置
module.exports = {
plugins: [
require('autoprefixer')
]
}
8.运行编译命令
npm run build
注意事项
编译css
时各loader
的顺序时从右到左执行的;
网友评论