这次给大家带来如何用vue设置proxyTable参数跨域,用vue设置proxyTable参数跨域的注意事项有哪些,下面就是实战案例,一起来看一下。 什么是代理跨域 浏览器之间有同源策略,出于安全考虑不同域之间不允许获取数据,除了几个特殊的例子 、、<audio>等标签可以进行跨域但是通常都是以get的形式,如果用js的axios去远程获取的话进会触发同源政策,除非你服务端的代码设置了<a href="http://www.php.cn/html/html-HEAD-2.html" target="_blank">head</a>er同意让你访问,明显这很不合理呀!。现在不是都流行前后端的分离吗,后端代码跑掉了只剩下前端了,两个次元的代码我前端该怎么获取啊,感觉使用跨域好麻烦好难搞啊还不一定搞得到,这个时候就可以用到代理跨域了</p> <p style="text-align: left;"><span style="color: #ff0000"><strong>代理跨域原理</strong></span></p> <p style="text-align: left;">所谓代理就是代替前端而是用后端发出http请求,就如vue的脚手架中,要运行项目你要输入npm run dev或npm run start吧,这个命令其实打开它已经配置好的node服务器,vue脚手架的代理就是通过node来代替前台发起http请求,既然不是浏览器发起的请求那不是就很容易啦?</p> <p style="text-align: left;">vue脚手架如何代理跨域,找到在config文件夹下的index.js文件,文件中有个dev,在里面找到proxyTable{},对它进行修改</p> <div class="code" style="position:relative; padding:0px; margin:0px;"><pre>proxyTable: { '/api': { target: 'https://www.xxx.com/',//你要跨的域 changeOrigin: true, pathRewrite: { '^/api': '/api', }, headers:{ //这边可以堆headers进行设置 } }, },</pre><div class="contentsignin">登录后复制</div></div> <p style="text-align: left;">其中target是你要跨域的地址,/api是你所跨的域下的下一级路径,像上面这样就是获取https://www.xxx.com/api下的东西,然后我们引入一个ajax的包axios并进行ajax</p> <div class="code" style="position:relative; padding:0px; margin:0px;"><pre>import axios from 'axios' axios.get('/getMessage').then(()=>{})</pre><div class="contentsignin">登录后复制</div></div> <p>相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!</p> <p>推荐阅读:</p> <p><a href="http://www.php.cn/js-tutorial-398343.html" target="_blank">在Vue里CSS Modules优雅使用方法</a><br></p> <p><a href="http://www.php.cn/js-tutorial-398346.html" target="_blank">怎样处理JS中双击和单击事件冲突问题</a><br></p>