VUE使用this.$http.jsonp报错Uncaught in promise Response

jsonp请求原理

  • 浏览器只对XHR(XMLHttpRequest)请求有同源请求限制,而对script标签src属性、link标签ref属性和img标签src属性没有这这种限制,利用这个“漏洞”就可以很好的解决跨域请求。JSONP就是利用了script标签无同源限制的特点来实现的,当向第三方站点请求时,我们可以将此请求放"</script/>"标签的src属性里,这就如同我们请求一个普通的JS脚本,可以自由的向不同的站点请求需要的资源,

  • 已经知道有一种叫做JSON的纯字符数据格式可以简洁的描述复杂数据,JSON还被js原生支持,所以在客户端几乎可以随心所欲的处理这种格式的数据。

  • web客户端通过与调用脚本一模一样的方式,来调用跨域服务器上动态生成的js格式文件(一般以JSON为后缀),显而易见,服务器之所以要动态生成JSON文件,目的就在于把客户端需要的数据装入进去。

  • 客户端在对JSON文件调用成功之后,也就获得了自己所需的数据,剩下的就是按照自己需求进行处理和展现了,这种获取远程数据的方式看起来非常像AJAX,但其实并不一样。*

  • 为了便于客户端使用数据,逐渐形成了一种非正式传输协议,人们把它称作JSONP,该协议的一个要点就是允许用户传递一个callback参数给服务端,然后服务端返回数据时会将这个callback参数作为函数名来包裹住JSON数据,这样客户端就可以随意定制自己的函数来自动处理返回数据了。

VUE代码

 getDate: function () {
 	this.$http.jsonp('http://localhost:8082/select/selectUser?currentPage=1&currentCount=5&text=1').then(function (res) {
    this.projectList = res.body
    })
}

jsonp请求

在这里插入图片描述

请求结果

在这里插入图片描述

错误原因

  • 因为请求返回的是一个数组类型,并不是json类型的字符串,所以会报错.(jsonp只支持json的返回类型)
Logo

前往低代码交流专区

更多推荐