vue项目部署线上环境css访问public的静态资源问题

vue项目部署线上环境css访问public的静态资源问题

这段时间在部署vue项目的时候,默认的端口已经代理了其他项目,那nginx上只能再拼接一段的代理路径

location /gasFrame {
  alias /usr/software/gas16-9/dist;
  add_header Access-Control-Allow-Origin *;
  allow all;
  index index.html index.htm index.php;
}

加了这一段后,自然而然vue.config.js也是需要加publicPath

module.exports = {
    publicPath: process.env.NODE_ENV === "production" ? "/gasFrame/" : "",
  };

发现竟然部分静态资源无法访问,比如http://192.168.20.99:8990/img/bb.png,我也好奇为什么这个图片资源没有加gasFrame的一个前缀,原来是这个背景图片当时css的样式是直接访问public下的文件夹的,而public下的资源是不会经过打包压缩的,src下资源才会经过打包压缩,所以我其他地方访问asset下的图片http://192.168.20.99:8990/gasFrame/img/icon.7653ab.png都可以访问到,因此访问public下的资源都需要拼接一段publicPath的前缀,当我想在css上拼接的时候,这个就有点麻烦,需要用到定义变量。

  • 首先定义变量

    export default class HelloWorld extends Vue {
      private backgroundImage: any = 'url('+process.env.BASE_URL+'/img/bb.png'+')';
    }
    
  • 然后在对应的标签引用该变量

    <img  height="70" width="70" id="tupian"  :style="{'--backgroundImage':backgroundImage}"/>
    
  • 最后在css样式上指向该标签的引用

    <style scoped lang="less">
    #tupian{
      background-image: var(--backgroundImage);
    }
    </style>
    

    这样就可以在css上引用到全局变量,如果是直接是放在src属性下就更好改了,只需要在文件的data定义一下publicPath,直接引用就行

    <img :src="${publicPath}my-image.png">
    export default class HelloWorld extends Vue {
      private publicPath: any = process.env.BASE_URL;
    }
    
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值