1、服务端代码



let express=require('express')
let app=express()
app.get('/',(req,res)=>{
let fn=req.query.callback //fn='zl'
let data=JSON.stringify({
data:"hahaha"
})
res.end(fn+`(${data})`)
})
app.listen(80,()=>{
console.log('serve is running...')
})


2、客户端代码



<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script src="../../node_modules/jquery/dist/jquery.js"></script>
</head>
<body>
<script type="text/javascript">
function zl(res){
console.log(res) //输出:{data:"hahaha"}
}
</script>
<script src="http://localhost:80/?callback=zl"></script>
</body>
</html>


执行过程如下:

1、<script src="http://localhost:80/?callback=zl"></script>发送请求

2、服务端收到请求let fn=req.query.callback此时fn的值就是’zl’

3、服务端向客户端返回数据,经过字符串拼接,返回给客户端的其实是zl({data:“hahaha”})

4、客户端收到服务端返回的内容:zl({data:“hahaha”})

5、客户端将zl({data:“hahaha”})解析为调用了zl函数且入参为{data:“hahaha”},所以最终客户端打印了{data:“hahaha”}

综上,其实jsonp的原理很简单,就是利用了script标签可以跨域请求这一特点,前端把方法作为参数传到服务端,然后服务端将数据作为方法的入参返回给前端,这样就能实现前后端通信。

扩展

使用ajax跨域:



$.ajax({
type: "GET",
url: "http://localhost:80/",
dataType: "jsonp",//
jsonp: "callback",//此参数的值与服务器端的req.query.callback对应
success: function (data) {
console.log(data)//输出:{data:"hahaha"}
},
error: function (err) {
console.log(err)
console.log('请求错误')
}
});