webpack4.0基础
安装
yarn add webpack webpack-cli -D npx webpack index.js
图片
file-loader
module: {
rules: [
{
test: /\.(jpg|png|gif)$/,
use: {
loader: 'file-loader',
options: {
name: '[name]_[hash].[ext]', // 占位符
outputPath: 'images/'
}
}
}
]
},
把图片打包成64位字符串
url-loader
module: {
rules: [
{
test: /\.(jpg|png|gif)$/,
use: {
loader: 'url-loader',
options: {
name: '[name]_[hash].[ext]', // 占位符
outputPath: 'images/',
limit:
}
}
}
]
},
样式
style-loader
在HTML中创建一个style标签,标签内容是css
css-loader
允许JS中import一个css文件,把css文件当成一个模块
{
test: /\.css$/,
use: ['style-loader', 'css-loader']
}
sass-loader / node-sass
{
test: /\.scss$/,
use: ['style-loader', 'css-loader', 'sass-loader']
}
postcss-loader
浏览器前缀
{
test: /\.scss$/,
use: [
'style-loader',
{
loader:'css-loader',
options: {
importLoaders:
}
}
'sass-loader',
'postcss-loader'
]
}
配置postcss.config.js
安装 autoprefixer
module.exports = {
plugins: [
require('autoprefixer')
]
}
模块化css
{
loader:'css-loader',
options: {
importLoaders: ,
modules: true
}
},
在js中引入模块css
import style from './assets/styles/global.scss' img.classList.add(style.avatar)
字体文件
file-loader
{
test: /\.(eot|svg|ttf|woff)/,
use: 'file-loader'
},
HTML模板
html-webpack-plugin
会在打包结束后生成一个HTML文件,并把打包生成的JS自动引入到HTML文件中
const HtmlWebpackPlugin = require('html-webpack-plugin') plugins: [new HtmlWebpackPlugin({
template: './index.html'
})],
删除打包文件dist
clean-webpack-plugin
const CleanWebpackPlugin = require('clean-webpack-plugin') new CleanWebpackPlugin()
devtool
打包生成的代码出错的时候,可以通过source map 定位错误在哪一行
devtool: 'none' // source-map
// cheap-module-eval-source-map 开发环境
// cheap-module-source-map // 线上环境
devServer
webpack-dev-server
启动服务器
devServer: {
contentBase:'/dist' // 在哪个文件启动服务器
},
package.json
"start": "webpack-dev-server",
配置跨域
proxy: {
"/api": "http://localhost:3000"
}
热模块替换(HMR)
// devServer
devServer: {
contentBase:'/dist',
hot: true,
hotOnly: true
},
// plugins
plugins: [
new webpack.HotModuleReplacementPlugin()
],
if (module.hot) {
module.hot.accept()
}
Babel
babel-loader @babel/core
{ test: /\.js$/, exclude: /node_modules/, loader: "babel-loader" }
@babel/preset-env / @babel/plugin-transform-runtime / @babel/runtime / @babel/runtime-corejs2
{
"presets": [
["@babel/preset-env",
]
], "plugins": [
[
"@babel/plugin-transform-runtime", {
"corejs": ,
"helpers": true,
"regenerator": true,
"useESModules": false
}
]
]
}
React
@babel/preset-react
{
"presets": ["@babel/preset-react"]
}
完整配置
const { resolve } = require('path')
const webpack = require('webpack')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const CleanWebpackPlugin = require('clean-webpack-plugin') module.exports = { mode: 'development',
entry: './src/index.js',
output: {
filename:'[name]-[hash].js',
path: resolve(__dirname, 'dist')
},
devtool:'cheap-module-eval-source-map',
devServer: {
contentBase:resolve(__dirname, 'dist'),
hot: true,
hotOnly: true
},
plugins: [
new CleanWebpackPlugin(),
new HtmlWebpackPlugin({
template: resolve(__dirname, 'public/index.html')
}),
new webpack.HotModuleReplacementPlugin()
],
module: {
rules: [
{
test: /\.css$/,
use: [
'style-loader',
{
loader:'css-loader',
options: {
importLoader:
}
},
'postcss-loader'
]
},
{
test: /\.scss$/,
use: [
'style-loader',
{
loader: 'css-loader',
options: {
importLoaders:
}
},
'sass-loader',
'postcss-loader'
]
},
{
test: /\.(png|jpg|gif)$/,
use: 'url-loader'
},
{
test: /\.(wof)$/,
use: 'file-loader'
},
{
test: /\.js$/,
exclude: /node_modules/,
use: 'babel-loader'
}
]
}
}
webpack4.0基础的更多相关文章
- webpack4.0各个击破(1)—— html部分
webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...
- webpack4.0各个击破(2)—— CSS篇
webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...
- webpack4.0各个击破(3)—— Assets篇
目录 一. Assets资源的基本处理需求 二. webpack处理引用资源 2.1 资源打标 2.2 引用优化 2.3 sprites雪碧图合成 2.4 图片压缩及其他 webpack作为前端最火的 ...
- webpack4.0各个击破(4)—— Javascript & splitChunk
目录 一. Js模块化开发 二. Js文件的一般打包需求 三. 使用webpack处理js文件 3.1 使用babel转换ES6+语法 3.2 脚本合并 3.3 公共模块识别 3.4 代码分割 3.5 ...
- webpack4.0各个击破(5)—— Module篇
webpack4.0各个击破(5)-- Module篇 webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决 ...
- webpack4.0各个击破(6)—— Loader篇
webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...
- webpack4.0各个击破(7)—— plugin篇
webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...
- webpack4.0各个击破(8)—— tapable篇
webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...
- webpack4.0各个击破(9)—— karma篇
webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...
随机推荐
- springboot集成redis报错-ClassNotFoundException: org.apache.commons.pool2.impl.GenericObjectPoolConfig
当使用Springboot 2.0以上版本集成redis的时候遇到报错信息如下: Application run failed org.springframework.beans.factory.Un ...
- Zabbix搭建部署与概述(一)
搭建部署与概述(一) 链接:https://pan.baidu.com/s/1q5YwJMTcZLcS5OQ0iOu44A 提取码:8gdi 复制这段内容后打开百度网盘手机App,操作更方便哦 1. ...
- 一篇不一样的Android屏幕适配具体做法(原创)
转载请注明出处(http://www.cnblogs.com/weizhxa/p/7568090.html ) 有不正确,还请大家留言修正! 1.何谓屏幕适配:在任何设备上看起来布局都是近似的,细分也 ...
- 70. SequenceInputStream(文件合并)
缓冲输入字节流:----------------------| InputStream 输入字节流的基类----------------| FileInputStream 读取文件的输入字节流--- ...
- C中的lvalue和rvalue
该贴子第一条回答虽然浅尝辄止,但还是很有参考价值. https://www.quora.com/What-is-lvalue-and-rvalue-in-C IBM一个简单的说法是: "-通 ...
- Ecshop商品浏览历史样式修改方法
想要修改ECSHOP的浏览历史样式,发现 history.lbi 中不能修改. 需要修改的文件:includes\lib_insert.php,找到函数:function insert_history ...
- 【NOI2019模拟2019.6.29】组合数(Lucas定理、数位dp)
Description: p<=10且p是质数,n<=7,l,r<=1e18 题解: Lucas定理: \(C_{n}^m=C_{n~mod~p}^{m~mod~p}*C_{n/p} ...
- K8S 容器之间通讯方式
概述 首先k8s里面容器是存在于pod里面的,所以容器之间通讯,一般分为三种类型: 1. pod内部容器之间 2. pod 与 pod 容器之间 3. pod 访问service服务 pod内部容器之 ...
- MFC弹出选择文件和选择文件夹代码
选择文件夹 TCHAR szSelectedDir[]; BROWSEINFO bi; ITEMIDLIST *il; bi.hwndOwner = m_hWnd; bi.pidlRoot = NUL ...
- TeleportPoint可瞬移的目标位置
TeleportPoint.png 最外部的组件: Animation: 包含了该装置的几个动画Teleport Point: 点传送的脚本 teleport_marker_mesh: 外部的圆柱形光 ...