vue jsonp 跨域调用 腾讯地图 api报错

栏目: Json · 发布时间: 5年前

内容简介:今天帮助前端小伙伴解决了一下 jsonp 调用腾讯地图 WebService API 报错项目中使用本来到了这里应该是完美无缺,开开心心的接受腾讯地图返回的信息就可以了,但是!!,出来了莫名其妙的问题,当请求接口是返回的确是

今天帮助前端小伙伴解决了一下 jsonp 调用腾讯地图 WebService API 报错 Unexpected token : 的问题,这里记录一下解决过程

项目中使用 vue-jsonp 组件来解决跨域问题,使用流程如下

安装 jsonp

npm install vue-jsonp

main.js 引入 jsonp 组件

import Vue from 'vue'
import VueJsonp from 'vue-jsonp'
Vue.use(VueJsonp)

接口调用

const KEY =XXXXXXXXXXXXXX; //key 秘钥自己申请
	        let url = 'https://apis.map.qq.com/ws/geocoder/v1?&poi_options=address_format=short&get_poi=0';
	        let locationdata = lat+','+lng //纬度,经度
	        this.$jsonp(url,{
	          key:KEY,
	          location:locationdata
	        })
			.then(json => {
				let address = json.result.address;
	            console.log(address) //附近街道地址信息
					})
				.catch(err => {
						console.log(err)
				})
	      }

本来到了这里应该是完美无缺,开开心心的接受腾讯地图返回的信息就可以了,但是!!,出来了莫名其妙的问题,当请求接口是返回的确是 Unexpected token : 这样的错误。

问题排查

本着发现问题解决问题的 程序员 精神,开始了百度 ,谷歌的混合双打,依然没有找到问题的原因,只因为当时搜索的关键词为 Unexpected token : 虽然我本身不是做前端,但是我也清除这种错误一抓一大把,很难精准的把握到错误的具体位置,既然问题出现在了 jsonp 中那就了解一下 jsonp 的实现原理,和跨域原理,果然有重大发现下图中的一段话一句惊醒梦中人

vue jsonp 跨域调用 腾讯地图 api报错

既然 jsonp 是要配合接口域名实现的服务端做配合那么,是不是腾讯那边也需要我来告诉它一下,我是通过 jsonp 调用的呢?于是果断查了一下接口文档,然后结果不出所料,接口中需要加入 output 参数来告诉腾讯地图访问请求为 jsonp 具体文档如下图

vue jsonp 跨域调用 腾讯地图 api报错

当我告诉前端小伙伴传入此参数时,果然接口正常访问了,到此问题解决。

summary

出现这种问题最主要的问题是没有仔细的阅读文档,只关注了自己需要传值部分,忽略了一些参数,有些还是比较重要的参数(像这次)。

其次就是我本身基础没有足够的扎实,对 jsonp 实现原理不熟悉,导致问题出现了,没有通过代码检查解决问题,而是通过百度和谷歌解决问题。

此次时间我个人也是一个惊醒,首先就是一定要仔细看接口文档,其二就是对知识要不求甚解,以前对 jsonp 了解太少,不够深刻,导致问题出现并不能精准定位。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法交易:制胜策略与原理

算法交易:制胜策略与原理

[美]欧内斯特·陈(Ernest P. Chan) / 高闻酉、黄蕊 / 机械工业出版社 / 49.00

本书是一本引人入胜、信息量大、覆盖各类交易策略的图书。无论个人投资者,还是机构投资者,都可以借鉴和使用其中的策略。本书中的策略大致可分为均值回归系统和动量系统两大类。书中不仅介绍了如何使用每种类别的交易策略,更解释了各种策略之所以有效的原因。本书始终以简单、线性的交易策略为重心,因为复杂的交易策略容易受到过度拟合及数据窥探的侵害。数学和软件是算法交易的两条腿。本书用到了一定程度的数学知识,使其对各......一起来看看 《算法交易:制胜策略与原理》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具