Vue动态加载图片在跨域时无法显示的问题及解决方法
写在前面
小记,就简单写了。问题:VUE开发时因为要访问后端的接口所以要配置请求转发,如果直接转发全部请求,那么VUE动态绑定的src也会转发到后端,因为图片在前端,所以会收到404NOTFOUND的报错。
常规的请求转发
在vue-cli3内,直接编辑vue.config.js,如下:
letproxyObj={}; proxyObj['/']={ ws:false, target:'http://localhost:8023',//后端地址 changeOrigin:true, pathRewrite:{ '^/':'' } }; module.exports={ devServer:{ host:'localhost', port:8080, proxy:proxyObj } };
代码很简单,就不解释了,这段代码就是把所有请求都转发到了后端。
常规的src动态绑定
如下:
//position.duiduorob为data内定义的字段
值得注意的是,需要用require(``)这样的方法,如果直接填写图片地址如:
浏览器内会找不到该图片。原因:通常在编译运行后,图片会被webpack统一打包到localhost:8080/static/img/[文件名].png,因为是上述过程动态加载的,所以url-loader无法解析图片地址,所以导致上述方法中的图片无法在浏览器内显示。解决方法就是通过require(``)这样的方法将图片作为模块被加载。
跨域请求转发时找不到图片
前面也说了,就是因为转发了全部请求,所以上述require(``)过后,浏览器去后端找图片了,导致找不到。
解决思路:只转发要访问后端接口的请求,其它不变。
所以其实就是过滤一下,添加一个条件。如下:要访问后端的请求在url上加一个/api即可
letproxyObj={}; proxyObj['/api']={//url前部加上'/api' ws:false, target:'http://localhost:8023',//后端地址 changeOrigin:true, pathRewrite:{ '^/api':''//到了后端去掉/api } }; module.exports={ devServer:{ host:'localhost', port:8080, proxy:proxyObj } };
所以在其他部分全部不变的情况下,只需在你封装的http请求方法内给url参数前加一个'/api'前缀,如下:
exportconstgetRequst=(url,params)=>{ returnaxios({ method:'get', url:'/api'+url,//原来为url:url, data:params, }) };
这下访问后端的请求全部在url上套上了'/api',而其它请求也不会被转发到后端了。
知识点补充:vue中解决跨域问题
方法1.后台更改header
header('Access-Control-Allow-Origin:*');//允许所有来源访问 header('Access-Control-Allow-Method:POST,GET');//允许访问的方式
方法2.使用JQuery提供的jsonp
methods:{ getData(){ varself=this $.ajax({ url:'http://f.apiplus.cn/bj11x5.json', type:'GET', dataType:'JSONP', success:function(res){ self.data=res.data.slice(0,3) self.opencode=res.data[0].opencode.split(',') } }) } }
方法3.使用http-proxy-middleware代理解决(项目使用vue-cli脚手架搭建)
例如请求的url:“http://f.apiplus.cn/bj11x5.json”
1、打开config/index.js,在proxyTable中添写如下代码:
proxyTable:{ '/api':{//使用"/api"来代替"http://f.apiplus.c" target:'http://f.apiplus.cn',//源地址 changeOrigin:true,//改变源 pathRewrite:{ '^/api':'http://f.apiplus.cn'//路径重写 } } }
2、使用axios请求数据时直接使用“/api”:
getData(){ axios.get('/api/bj11x5.json',function(res){ console.log(res) })
通过这中方法去解决跨域,打包部署时还按这种方法会出问题。解决方法如下:
letserverUrl='/api/'//本地调试时 //letserverUrl='http://f.apiplus.cn/'//打包部署上线时 exportdefault{ dataUrl:serverUrl+'bj11x5.json' }
附:
方法二引入jq
1.下载依赖
cnpminstalljquery--save-dev
2.在webpack.base.conf.js文件中加入
plugins:[ newwebpack.ProvidePlugin({ $:"jquery", jQuery:"jquery" }) ],
3.在需要的temple里引入也可以在main.js里全局引入
import$from'jquery'
eg:
source{{data}}
总结
到此这篇关于Vue动态加载图片在跨域时无法显示的问题及解决方法的文章就介绍到这了,更多相关vue动态加载图片跨域无法显示内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。