博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
webpack图片的路径与打包
阅读量:6040 次
发布时间:2019-06-20

本文共 2640 字,大约阅读时间需要 8 分钟。

转的http://www.cnblogs.com/ghost-xyx/p/5812902.html

今天写 react遇到打包图片,之前都是通过url在css里,没遇到问题,今天在 react里直接用就错了,所以记录下来,这篇文章帮我解决了。。。

 

刚开始用webpack的同学很容易掉进图片打包这个坑里,比如打包出来的图片地址不对或者有的图片并不能打包进我们的目标文件夹里(bundle)。下面我们就来分析下在webpack项目中图片的应用场景。

在实际生产中有以下几种图片的引用方式:

1. HTML文件中img标签的src属性引用或者内嵌样式引用

2. CSS文件中的背景图等设置

.photo {    background: url(photo.jpg);}

3. JavaScript文件中动态添加或者改变的图片引用

var imgTempl = '';document.body.innerHTML = imgTempl;

4. ReactJS中图片的引用

import React from 'react';import ReactDOM from 'react-dom';class App extends React.Component {    render() {        return ();    }}ReactDom.render(
, document.querySelector('#container'));

 

url-loader

在 webpack 中引入图片需要依赖 url-loader 这个加载器。

安装:

npm install url-loader --save-dev

当然你可以将其写入配置中,以后与其他工具模块一起安装。

在 webpack.config.js 文件中配置如下:

module: {  loaders: [    {      test: /\.(png|jpg)$/,      loader: 'url-loader?limit=8192'    }  ]}

test 属性代表可以匹配的图片类型,除了 png、jpg 之外也可以添加 gif 等,以竖线隔开即开。

loader 后面 limit 字段代表图片打包限制,这个限制并不是说超过了就不能打包,而是指当图片大小小于限制时会自动转成 base64 码引用。上例中大于8192字节的图片正常打包,小于8192字节的图片以 base64 的方式引用。

url-loader 后面除了 limit 字段,还可以通过 name 字段来指定图片打包的目录与文件名:

module: {  loaders: [    {      test: /\.(png|jpg)$/,      loader: 'url-loader?limit=8192&name=images/[hash:8].[name].[ext]'    }  ]}

 上例中的 name 字段指定了在打包根目录(output.path)下生成名为 images 的文件夹,并在原图片名前加上8位 hash 值。

例:工程目录如下

在 main.css 中引用了同级 images 文件夹下的 bg.jpg 图片

background-image: url(./images/bg.jpg);

通过之前的配置,使用 $ webpack 命令对代码进行打包后生成如下目录

打包目录中,css 文件和 images 文件夹保持了同样的层级,可以不做任务修改即能访问到图片。区别是打包后的图片加了 hash 值,bundle.css 文件里引入的也是有hash值的图片。

background-image: url(images/f593fbb9.bg.jpg);

 (上例中,使用了单独打包css的技术,只是为了方便演示)

 

publicPath

output.publicPath 表示资源的发布地址,当配置过该属性后,打包文件中所有通过相对路径引用的资源都会被配置的路径所替换。

output: {  path: 'dist',  publicPath: '/assets/',  filename: 'bundle.js'}

 main.css

background-image: url(./images/bg.jpg);

 bundle.css

background-image: url(/assets/images/f593fbb9.bg.jpg);

该属性的好处在于当你配置了图片 CDN 的地址,本地开发时引用本地的图片资源,上线打包时就将资源全部指向 CDN 了。

但是要注意,如果没有确定的发布地址不建议配置该属性,否则会让你打包后的资源路径很混乱。

 

JS中的图片

初用 webpack 进行项目开发的同学会发现:在 js 或者 react 中引用的图片都没有打包进 bundle 文件夹中。

正确写法应该是通过模块化的方式引用图片路径,这样引用的图片就可以成功打包进 bundle 文件夹里了

js

var imgUrl = require('./images/bg.jpg'),    imgTempl = '';document.body.innerHTML = imgTempl;

react

render() {    return ();}

 

HTML中的图片

由于 webpack 对 html 的处理不太好,打包 HTML 文件中的图片资源是相对来说最麻烦的。这里需要引用一个插件—— html-withimg-loder

$ npm install html-withimg-loader --save-dev

 webpack.config.js 添加配置

module: {  loaders: [    {      test: /\.html$/,      loader: 'html-withimg-loader'    }  ]}

在 bundle.js 中引用 html 文件

import '../index.html';

这样 html 文件中的图片就可以被打包进 bundle 文件夹里了。

 

感谢您的浏览,希望能有所帮助

转载于:https://www.cnblogs.com/huenchao/p/6123515.html

你可能感兴趣的文章
【原创】MySQL 返回更新值(RETURNING)
查看>>
MySQL常见错误代码(error code)及代码说明
查看>>
感恩的心,感谢有你--51CTO!
查看>>
大数据虚拟化之常见问题汇总1
查看>>
你不一定真正理解的NAT术语
查看>>
技术人的危机-非理性的繁荣
查看>>
我的家庭私有云计划-11
查看>>
远程redhat linux oracle11g安装
查看>>
如何与非同盟组织分享日历
查看>>
架设基于FreeRADIUS带有认证计费功能的Open***
查看>>
Flask blueprint蓝图按功能模块化架构实例
查看>>
Sybase ASE Database Devices Administrator Guide (二)
查看>>
SQL Server 2016 实时查询统计(Live Query Statistics)
查看>>
SVN版本管理工具使用手册
查看>>
Appium Python API 汇总
查看>>
股票量化交易回测框架pyalgotrade源码阅读(一)
查看>>
Windows Phone7成为诺基亚核心目标
查看>>
Nginx 随笔
查看>>
Linux系统高可用集群软件之HeartBeat
查看>>
如何提高Linq查询的性能(上)
查看>>