webpack打包后的静态资源问题

情景:
使用webpack 打包前端应用后,图片和css、js 资源引用会出问题,
这源于开发环境的目录和生产环境的路径【url】不同
比如,开发环境的url是:
http://localhost:8088/static/...

而生产环境的url是:
http://www.xxx.com/aaa/bbb/st...

其中【http://www.xxx.com/aaa/bbb/】是配置的生产环境路由。
指向express服务器。

二者区别,开发环境是放在域名的根目录,所以不存在引用路径变化的问题。
如果生产环境不做处理的话,图片等静态文件会自动在相对路径前添加域名。
比如:

在样式中写到:
background:url(abc.png)
这里会自动被转化为:
http://www.xxx.com/abc.png
然而,除非项目放在了域名根目录下,一般情况这是路径是不对的。

解决方案:
webpack 是个优秀的打包工具,肯定有相关的配置的。
在build配置脚本中,就有相关配置项:
图片描述

其中: index: path.resolve(__dirname, '../dist/index.html'),
表示,打包后的入口index.html文件存放的位置,这里表示,在dist目录下。
assetsRoot: path.resolve(__dirname, '../dist')
表示,打包后埔静态资源文件存放的根目录,表示同样是dist目录。
assetsSubDirectory: 'static',
表示静态文件打包后存放的子目录,'/static'
assetsPublicPath: '/',
这个表示静态资源部署后的公共路径。
假如应用路径是【http://www.xxx.com/aaa/bbb/
那么这里就应该配置为'/aaa/bbb/'
如果需要传到cdn,则可以改成http://stacic.xxx.com/aaa/bbb/

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值