两个页面之间需要交流
发送请求方法进化过程:
1.form表单提交会刷新页面
|
2.img,只能知道成功或失败,没法传参
|
3.script,需要指定执行什么
|
JSONP
node文件系统
fs.readFileSync('路径', 'utf-8')读取文件的内容
fs.writeFileSync('路径',写入的内容, 'utf-8')
response.write('success') 会跳转到path,显示success
用script 或img标签发送请求SRJ
直接改端口:
用script scr可实现两个网站之间交流,a调b的后台。
缺点:两个页面需要耦合(要求紧密相连)
要解耦:后台调函数执行
怎么知道是xxx函数:
url传参:
query取参
JSONP(动态标签跨域请求)
返回一个{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方法