内容简介:在讲 JSONP 之前需要再来回顾一下在页面上使用 script 引入外部的 js 文件时到底引入了什么?先建立一个 index.js 文件。再建立一个 index.html 文件。
JSONP
在讲 JSONP 之前需要再来回顾一下在页面上使用 script 引入外部的 js 文件时到底引入了什么?
先建立一个 index.js 文件。
console.log(123)
再建立一个 index.html 文件。
<!DOCTYPE html>
<html lang='en'>
<head>
<meta charset='utf-8'>
<title>JSONP</title>
</head>
<body>
<script src='index.js'></script>
</body>
</html>
上面的
<script src='index.js'></script>
等价于
<script> console.log(123) </script>
现在再来看 JSONP 就比较好理解了。
假设我现在需要向 www.abc.com 上请求一个资源 asset。我需要先创建一个 script 标签令其 src 等于这个源来访问这个资源
<script src= 'http://www.abc.com/?dataName=asset&callback=handleResponse'></script>
根据上面的举例我们知道 script 返回的就是一段 JS 代码,那么服务器在接收到我们的请求时,如果给我们返回一段 JS 代码,这段代码可以是一个函数执行的代码,而且函数的参数可以就是我们请求的资源。
例如上面的 handleResponse
函数在本地的定义如下:
handleResponse(asset) {
console.log('从服务端得到的资源 asset 为', asset)
}
服务端给我们返回的 JS 代码如下:
handleResponse(asset)
在script 标签就相当于
<sctript> handleResponse(asset) </sctript>
handleResponse
在本地又有定义,服务端的资源 asset 也通过函数参数的形式传递下来了。
由于 asset 的形式往往是 JSON 的格式,所以这种跨域的方式被称为 JSONP。
JSONP 由两部分构成,
-
参数(JSON格式,就是服务端需要传递给客户端的数据
-
回调函数
名字要和浏览器端代码中定义的名字相同,在上面的例子中浏览器端定义的是
handleResponse,在服务端返回的函数名字也应该是handleResponse,只有这样在浏览器端接收到后才能进行调用。
图像 Ping
我们知道使用 script 标签返回的是一段 JS 代码,请问下面这段代码返回的是什么。
<img src='http://www.abc.com/?dataName=img1'>
往往返回的是一张图片,因此浏览器端是没有办法接收到服务端的返回值的。
虽然它不像 JSONP 使用那么广泛,但是还是有一定的用武之地的。
例如用于统计某个广告的点击次数,创建一个 img 标签,然后绑定一个 click 事件,当点击图片时给 img.src
赋值,这个时候就会向 'http://www.abc.com/count'
发送请求,服务端在接收到这个请求之后就可以令点击次数加 1.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<body>
<script>
const img = document.createElement('img')
img.onclick = function () {
img.src='http://www.abc.com/count'
}
document.appendChild(img)
</script>
</body>
</html>
注意这个例子并不严谨,这里主要是说明统计点击某个广告次数的思路,使用图像 Ping 是可以实现的。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
大数据供应链
娜达·R·桑德斯 (Nada R. Sanders) / 丁晓松 / 中国人民大学出版社 / 2015-7-1 / CNY 55.00
第一本大数据供应链落地之道的权威著作,全球顶级供应链管理专家娜达·桑德斯博士聚焦传统供应链模式向大数据转型,助力工业4.0时代智能供应链构建。 在靠大数据驱动供应链处于领先地位的企业中,45% 是零售商,如沃尔玛、亚马逊,而22%是快消企业,如戴尔电脑。他们都前所未有地掌控了自己的供应链。在库存管理、订单履行率、原材料和产品交付上具有更为广阔的视野。利用具有预见性的大数据分析结果,可以使供需......一起来看看 《大数据供应链》 这本书的介绍吧!