JSONP

两个页面之间需要交流
发送请求方法进化过程:
1.form表单提交会刷新页面
|
2.img,只能知道成功或失败,没法传参
|
3.script,需要指定执行什么
|
JSONP

node文件系统

fs.readFileSync('路径', 'utf-8')读取文件的内容
fs.writeFileSync('路径',写入的内容, 'utf-8')
response.write('success') 会跳转到path,显示success

用script 或img标签发送请求SRJ

image.png
image.png

直接改端口:


image.png

用script scr可实现两个网站之间交流,a调b的后台。


image.png

image.png

缺点:两个页面需要耦合(要求紧密相连)
要解耦:后台调函数执行


image.png
image.png

怎么知道是xxx函数:
url传参:


image.png

query取参


image.png

JSONP(动态标签跨域请求)

image.png

返回一个{json}

JSONP
请求方:A.com的前端(浏览器)
响应方:B.com的后端(服务器)
1.请求方创建script,src指向响应方,同时传一个查询参数?callbackName=xxx
2.响应方根据查询参数callbackName,构造形如
-xxx.call(undefined, '你要的数据')
-xxx('你要的数据')
3.浏览器接收到响应,就会执行xxx.call(undefined, '你要的数据'),请求方得到数据

约定:
1.不用callbackName,直接用callback
2.xxx函数使用随机数

    functionName = 'xxx'+parseInt(Math.random()+1000, 10)
在window上定义这个函数
window[functionName] = function (result){
code...
}
script.src="http://B.com"+functionName
 script.onload = function (e) {
        e.currentTarget.remove()  //移出标签
        delete window[functionName]    //删除函数
    }
    script.onerror = function (e) {
        e.currentTarget.remove()
        delete window[functionName]
    }

使用jQuery

在A页面写

jQuery.ajax({              //不是ajax,没关系
url:"http://B.com:8002/pay"
dataType: "jsonp",
success: function( response ){
console.log(response)     //success
if(response === 'success'){
请求成功的执行的code...
}
}
})

面试题

请问JSONP为什么不支持POST请求
答:
1.JSONP是通过创建动态script标签实现的
2.动态创建script只能用GET方法

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. JSONP的实现原理 JSONP是通过动态创建script实现的。请求方:frank.com 的前端程序员(...
    王童孟阅读 491评论 0 2
  • 本文是在了解了浏览器的同源规则之后,并学习一个破解这个规则的一个简单有效的方法JSONP。主要通过阮一峰老师的博客...
    吴少在coding阅读 692评论 0 2
  • 前端操作数据库 首先,我们试着通过前端来操作一个数据库。数据库是什么?只要能长久的存数据,就是数据库。文件系统是一...
    是刘快啊阅读 393评论 0 2
  • 页面数据交互的发展过程 付款是我们日常中常见的一种金钱交易,用户在页面中点击付款按钮,网页提交请求给服务器,服务器...
    鹧鸪少阅读 946评论 0 0
  • 什么是同源策略 同源策略/SOP(Same origin policy)是一种约定,由Netscape公司1995...
    YQY_苑阅读 341评论 0 0