#box1 {
width: 100px;
height: 100px;
background-color: pink;
}
b.css文件:
#box2 {
width: 200px;
height: 200px;
background-color: deeppink;
}
index.js文件:
import '../css/a.css';
import '../css/b.css';
index.html文件:
<div id="box1"></div>
<div id="box2"></div>
npm install --save-dev mini-css-extract-plugin
const {
resolve } = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
module.exports = {
entry: './src/js/index.js',
output: {
filename: 'js/built.js',
path: resolve(__dirname, 'build')
},
module: {
rules: [
{
test: /\.css$/,
use: [
// 'style-loader', // 创建style标签,将样式放入
MiniCssExtractPlugin.loader,// 这个loader取代style-loader。作用:提取js中的css成单独文件
// 将css文件整合到js文件中
'css-loader'
]
}
]
},
plugins: [
new HtmlWebpackPlugin({
template: './src/index.html'
}),
new MiniCssExtractPlugin({
// 对输出的css文件进行重命名
filename: 'css/built.css'
})
],
mode: 'development'
};
webpack
css兼容性处理:postcss --> postcss-loader postcss-preset-env
postcss-preset-env插件的作用是:
帮 postcss 找到 package.json 中 browserslist 里面的配置,通过配置加载指定的css兼容性样式
除了 a.css文件需要修改,其他的上一节文件即可:
a.css文件:
#box1 {
width: 100px;
height: 100px;
background-color: pink;
display: flex;
backface-visibility: hidden;
}
npm install --save-dev postcss-loader postcss-preset-env
视频中 webpack4 是这样做的,加入下述代码:
{
loader: 'postcss-loader',
options: {
ident: 'postcss',
plugins: () => [
// postcss的插件
require('postcss-preset-env')()
]
}
}
如下图所示:
但是 webpack5 这样写会报错。webpack5的可以这样做:
module.exports = {
plugins: [
// postcss的插件
require('postcss-preset-env')
]
}
'postcss-loader',
"browserslist":{
"development":[
"last 1 chrome version",
"last 1 firefox version",
"last 1 safari version"
],
"production":[
">0.2%",
"not dead",
"not op_mini all"
]
},
其中 “last 1 chrome version” 代表 兼容最近的一个 chrome 版本;
“>0.2%” 代表 大于99.8%的浏览器;
"not dead"代表不要已经死了的浏览器
在 webpack.config.js 文件中加入下面代码,如下图所示:
// 设置nodejs环境变量
process.env.NODE_ENV = 'development';
webpack
npm install --save-dev optimize-css-assets-webpack-plugin
加入以下代码:
const optimizeCssAssetsWebpackPlugin = require('optimize-css-assets-webpack-plugin');
//压缩css
new optimizeCssAssetsWebpackPlugin()
webpack
function add(x, y) {
return x + y;
}
console.log(add(2, 5));
index.html文件:
<h1>hello webpack</h1>
npm install --save-dev eslint-loader eslint eslint-config-airbnb-baseeslint-plugin-import
const {
resolve } = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
module.exports = {
entry: './src/js/index.js',
output: {
filename: 'js/built.js',
path: resolve(__dirname, 'build')
},
module: {
rules: [
{
test: /\.js$/,
exclude: /node_modules/,
loader: 'eslint-loader',
options: {
// 自动修复eslint的错误
fix: true
}
}
]
},
plugins: [
new HtmlWebpackPlugin({
template: './src/index.html'
})
],
mode: 'development'
};
"eslintConfig":{
"extends":"airbnb-base",
"env":{
"browser":true
}
},
webpack
上线时 console.log(add(2, 5));
这种代码最好不要写,但是如果是调试阶段,可以用eslint-disable-next-line
忽略它,不进行eslint检查,如下图所示:
const add = (x, y) => {
return x + y;
};
console.log(add(2, 5));
const promise = new Promise(resolve => {
setTimeout(() => {
console.log('定时器执行完了~');
resolve();
}, 1000);
});
console.log(promise);
index.html文件:
<h1>hello webpack</h1>
这里我将下面会提到的所有需要下载的都下载了
npm install --save-dev babel-loader @babel/core @babel/preset-env @babel/polyfill core-js
问题:如果只想解决部分兼容性问题,但是将所有兼容性代码全部引入,体积太大了~
{
test: /\.js$/,
exclude: /node_modules/,
loader: 'babel-loader',
options: {
// 预设:指示babel做怎么样的兼容性处理
presets: [
[
'@babel/preset-env',
{
// 按需加载
useBuiltIns: 'usage',
// 指定core-js版本
corejs: {
version: 3
},
// 指定兼容性做到哪个版本浏览器
targets: {
chrome: '60',
firefox: '60',
ie: '9',
safari: '10',
edge: '17'
}
}
]
]
}
}
注意:当使用第三种方式时,不能同时使用第二种,要将js中引入的第二种方式代码注释掉。如下图所示:
这里我用的第三种按需加载方式:
webpack
在实际中一般不用第二种方式,一般用第一种和第二种结合的方式。
生产环境下会自动压缩js代码,所以只需要将 mode 改为 production 即可
mode: 'production'
视频里是写了下述代码实现了html压缩,但是webpack5已经可以像上述所示自己压缩了
将上述整理在一起,即以下代码:
webpack.config.js代码:
const {
resolve } = require('path');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const OptimizeCssAssetsWebpackPlugin = require('optimize-css-assets-webpack-plugin');
const HtmlWebpackPlugin = require('html-webpack-plugin');
// 定义nodejs环境变量:决定使用browserslist的哪个环境
process.env.NODE_ENV = 'production';
// 复用loader
const commonCssLoader = [
// 这个loader取代sty7le-loader。作用:提取js中的css成单独文件
MiniCssExtractPlugin.loader,
// 将css文件整合到js文件中
'css-loader',
//css兼容性处理 还需要在package.json中定义browserslist
// 使用loader的默认配置
'postcss-loader',
];
module.exports = {
entry: './src/js/index.js',
output: {
filename: 'js/built.js',
path: resolve(__dirname, 'build'),
publicPath:'./'
},
module: {
rules: [
{
test: /\.css$/,
use: [...commonCssLoader]
},
{
test: /\.less$/,
use: [...commonCssLoader, 'less-loader']
},
/*
正常来讲,一个文件只能被一个loader处理。
当一个文件要被多个loader处理,那么一定要指定loader执行的先后顺序:
先执行eslint 在执行babel
*/
//JS语法检查
{
// 在package.json中eslintConfig --> airbnb
test: /\.js$/,
exclude: /node_modules/,
// 优先执行
enforce: 'pre',
loader: 'eslint-loader',
options: {
// 自动修复eslint的错误
fix: true
}
},
//JS兼容性处理
{
test: /\.js$/,
exclude: /node_modules/,
loader: 'babel-loader',
options: {
// 预设:指示babel做怎么样的兼容性处理
presets: [
[
'@babel/preset-env',
{
// 按需加载
useBuiltIns: 'usage',
corejs: {
// 指定core-js版本
version: 3
},
targets: {
// 指定兼容性做到哪个版本浏览器
chrome: '60',
firefox: '50'
}
}
]
]
}
},
{
test: /\.(jpg|png|gif)/,
loader: 'url-loader',
options: {
limit: 8 * 1024,
name: '[hash:10].[ext]',
outputPath: 'imgs'
}
},
{
test: /\.html$/,
loader: 'html-loader'
},
{
exclude: /\.(js|css|less|html|jpg|png|gif)/,
loader: 'file-loader',
options: {
outputPath: 'media'
}
}
]
},
plugins: [
new MiniCssExtractPlugin({
// 对输出的css文件进行重命名
filename: 'css/built.css'
}),
//压缩css
new OptimizeCssAssetsWebpackPlugin(),
new HtmlWebpackPlugin({
template: './src/index.html'
})
],
// 生产环境下会自动压缩js html 代码
mode: 'production'
};
package.json新增代码:
"browserslist": {
"development": [
"last 1 chrome version",
"last 1 firefox version",
"last 1 safari version"
],
"production": [
">0.01%",
"not dead",
"not op_mini all"
]
},
"eslintConfig": {
"extends": "airbnb-base",
"env": {
"browser": true
}
},
postcss.config.js代码:
module.exports = {
plugins: [
// postcss的插件
require('postcss-preset-env')
]
}