webpack 图片、字体、多媒体等资源的处理
webpack 搭建文档:https://webpack.eleven.net.cn
-
css 或 js 中引入的图片、字体、多媒体等静态资源,统一使用 url-loader 处理。
配置了 url-loader 以后,webpack 编译时可以自动将小文件转成 base64 编码,减少网络请求。如果不需要将小文件转成 base64 ,也可以用 file-loader 替换 url-loader。
-
安装依赖包
url-loader 内部会自动调用 file-loader,所以仍然需要安装。
yarn add url-loader file-loader -D
-
添加配置
// 处理图片(file-loader来处理也可以,url-loader更适合图片) { test: /\.(png|jpe?g|gif|svg)(\?.*)?$/, loader: 'url-loader', options: { limit: 10000, name: 'static/assets/images/[name].[hash:7].[ext]', }, }, // 处理多媒体文件 { test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/, loader: 'url-loader', options: { limit: 10000, name: 'static/assets/media/[name].[hash:7].[ext]', }, }, // 处理字体文件 { test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/, loader: 'url-loader', options: { limit: 10000, name: 'static/assets/fonts/[name].[hash:7].[ext]' } },
-
js中使用到静态资源,需要通过 import、require 导入再使用,才会被处理。
import img from 'xxx/xxx/123.jpg' 或 let img = require('xxx/xxx/123.jpg')
-
-
对于直接在 html 页面中通过标签引入的图片或其它静态资源,即使配置了 url-loader,webpack也不会去处理它们,可以使用 html-loader 处理。
-
安装依赖包
yarn add html-loader -D
-
添加配置
// html中引用的静态资源在这里处理,默认配置参数attrs=img:src,处理图片的src引用的资源. { test: /\.html$/, loader: 'html-loader', options: { // 除了img的src,还可以继续配置处理更多html引入的资源(不能在页面直接写路径,又需要webpack处理怎么办?先require再js写入). attrs: ['img:src', 'img:data-src', 'audio:src'], minimize: false, removeComments: true, collapseWhitespace: false } }
-
-
静态资源的访问路径问题
经过上面的处理,静态资源处理基本没有问题了,webpack 编译时将会将文件打包到你指定的生成目录,但是不同位置的路径url会是一个问题。全部通过绝对路径访问即可,在 output 下的 publicPath 填上适当的 server 端头,来保证所有静态资源文件能被访问到,具体要根据服务器部署的目录结构来做修改。
output: { path: path.resolve(__dirname, 'dist'), // 输出目录的配置,模板、样式、脚本、图片等资源的路径配置都相对于它 publicPath: '/', // 模板、样式、脚本、图片等资源对应的server上的路径 }
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。