file-loader与url-loader的区别

file-loader与url-loader的区别
相同点:file-loader与url-loader都是在webpack中引入图片的解决方案。
不同点:

1、file-loader:返回的是图片的public URL。
2、url-loader:与file-loader不同,url-loader可以在图片大小小于设定的limit的时候返回的是一个bDataURL(base64码),大于limit时会调用file-loader对图片进行处理。

两者关系:
简单说url-loader封装了file-loader,但url-loader不依赖于file-loader。
url的工作情况分两种情况:
1.文件大小小于limit参数,url-loader将会把文件转为DataURL;
2.文件大小大于limit,url-loader会调用file-loader进行处理,参数也会直接传给file-loader。因此我们只需要安装url-loader即可

踩坑经历:
问题:我使用的是file-loader,当我在项目中使用webpack-dev-server开始完毕后,页面所有图片浏览正常。然后使用webpack将项目打包出来后,页面中的所有图片加载失败。
原因:
1、经过webpack打包后,我的所有的资源都打包在一个js文件,此时图片的路径是相对入口html文件,而不是原来的文件。
2、我的webpack生产配置文件中的output中使用了publicPath,那么就导致了所有的图片的加载路径都是基于publicPath,导致文件404
解决方案:webpack生产配置文件中将output中pubicPath去掉或者将publicPath修改为打包文件目录。
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值