css-loader和file-loader/url-loader冲突无法显示图片

广告位招租
扫码页面底部二维码联系

最近在调试的时候,同事反馈说图片没有展示【转载请注明来源】【转载请注明来源】出来,去看了以后简直莫名奇妙,因为我自认【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。为对css-loader和file-lo【版权所有】唐霜 www.tangshuang.net【版权所有,侵权必究】ader的配置没有问题,难道css-lo【访问 www.tangshuang.net 获取更多精彩内容】【本文受版权保护】ader又挖了什么坑?于是开始漫长的调试【作者:唐霜】【版权所有】唐霜 www.tangshuang.net,测试过程。最终发现,问题是真的存在,而【未经授权禁止转载】转载请注明出处:www.tangshuang.net且我google了半天,恁是在国内外都没未经授权,禁止复制转载。转载请注明出处:www.tangshuang.net有找到靠谱的解决方法。调试过程中可以肯定转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】的是,css-loader竟然自己把ur【作者:唐霜】【版权所有】唐霜 www.tangshuang.netl()的图片生成到目录下了,然后file【转载请注明来源】【原创不易,请尊重版权】-loader又做了一遍:

本文版权归作者所有,未经授权不得转载。【作者:唐霜】原创内容,盗版必究。【版权所有】唐霜 www.tangshu【版权所有,侵权必究】【作者:唐霜】ang.net

本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。未经授权,禁止复制转载。

这也就意味着一张图片被处理了两次,具体造著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】成的问题是css-loader给的路径不【原创不易,请尊重版权】转载请注明出处:www.tangshuang.net对还是file-loader给的不对,就【访问 www.tangshuang.net 获取更多精彩内容】【未经授权禁止转载】不想去深究,总之就是两个loader冲突【关注微信公众号:wwwtangshuangnet】【版权所有,侵权必究】了。按照我以前的理解,css-loade本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。r只负责把url()转化为require【作者:唐霜】未经授权,禁止复制转载。()的形式,并不负责生成真实的图片,然后【版权所有】唐霜 www.tangshuang.net【本文受版权保护】file-loader可以识别requi著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。re(image)的形式,并生成图片,两原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.net个loader分工明确。那么这里是为什么【未经授权禁止转载】著作权归作者所有,禁止商业用途转载。呢?于是,我把file-loader从r本文作者:唐霜,转载请注明出处。【访问 www.tangshuang.net 获取更多精彩内容】ules中去掉,然后……图片竟然展示出来转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。了!!

转载请注明出处:www.tangshua本文作者:唐霜,转载请注明出处。【作者:唐霜】ng.net【访问 www.tangshuang.n转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。et 获取更多精彩内容】【版权所有,侵权必究】

所以说,无论是css-loader的问题【原创内容,转载请注明出处】【原创内容,转载请注明出处】,还是结合webpack5一起的问题,现本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。在webpack5+新版css-load【版权所有,侵权必究】【未经授权禁止转载】er就可以自己把图片处理到目标目录下了。【版权所有,侵权必究】【关注微信公众号:wwwtangshuangnet】然而,问题在于,如果去掉file-loa【版权所有,侵权必究】未经授权,禁止复制转载。der,那么我们在js中是没有办法直接i【版权所有,侵权必究】转载请注明出处:www.tangshuang.netmport一张图片作为url来使用的。这【关注微信公众号:wwwtangshuangnet】【关注微信公众号:wwwtangshuangnet】就矛盾了。而且检查了file-loade著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】r的配置,也没有接口可以让我们忽略对cs【未经授权禁止转载】本文作者:唐霜,转载请注明出处。s文件中的图片进行排除。似乎就这样卡住了未经授权,禁止复制转载。【转载请注明来源】

【关注微信公众号:wwwtangshua【转载请注明来源】【访问 www.tangshuang.net 获取更多精彩内容】ngnet】【原创内容,转载请注明出处】转载请注明出处:www.tangshua【原创内容,转载请注明出处】【作者:唐霜】ng.net【原创内容,转载请注明出处】

于是重新回去阅读文档。

【关注微信公众号:wwwtangshua转载请注明出处:www.tangshuang.net原创内容,盗版必究。ngnet】著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】

果然,不独不知道,webpack5现在已本文作者:唐霜,转载请注明出处。【转载请注明来源】经牛x到自己可以把非js的文件资源作为模【关注微信公众号:wwwtangshuangnet】【原创内容,转载请注明出处】块读取了。什么?不懂?意思就是,不需要f【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。ile-loader了,webpack内【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。置了工具!具体做法就是把我们配置文件中的 loader: 'file-loader' 一句改为 type: 'asset/resource' 就可以了。

本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。【转载请注明来源】

webpack的rule.type在v4【本文首发于唐霜的博客】【转载请注明来源】中就已经加入了,只是很少被用到,它的文档著作权归作者所有,禁止商业用途转载。【本文受版权保护】也说的不清不楚,我也不知道它有这个能力,转载请注明出处:www.tangshuang.net转载请注明出处:www.tangshuang.netasset/resource 也是到v5才悄悄加进去的,你可以查看v4的文档v5的文档的差异。

原创内容,盗版必究。转载请注明出处:www.tangshua【本文首发于唐霜的博客】【关注微信公众号:wwwtangshuangnet】ng.net

【版权所有】唐霜 www.tangshu【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。ang.net【版权所有】唐霜 www.tangshu【关注微信公众号:wwwtangshuangnet】本文作者:唐霜,转载请注明出处。ang.net本文版权归作者所有,未经授权不得转载。原创内容,盗版必究。

新增的asset这个选项就是对非js相关【版权所有】唐霜 www.tangshuang.net【原创内容,转载请注明出处】的资源的处理,它文档单独通过一节对这些项目进行解释,而且里面就明确提到可著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshuang.net以代替以前的file-loader, u转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。rl-loader, raw-loade著作权归作者所有,禁止商业用途转载。【本文受版权保护】r,然而,大哥你虽然可以代替,但是直接破本文版权归作者所有,未经授权不得转载。【转载请注明来源】坏原来的效果,是不是有点不厚道呀!

【原创不易,请尊重版权】【本文受版权保护】【版权所有】唐霜 www.tangshu【原创不易,请尊重版权】未经授权,禁止复制转载。ang.net【原创不易,请尊重版权】
已有4条评论
  1. HduSy 2024-01-29 19:06

    确实,如果升级后想用的话,可将`type: javascript/auto`,同时`esModule: false`

  2. HduSy 2024-01-27 12:17

    Cool

  3. ayu 2022-04-16 16:09

    Cool!

  4. rxliuli 2022-04-03 17:15

    来 vite 保平安(逃