首先科普一下域,这里只说前端的域。
前端的域是指服务器在网络上占据的地址。
跨域指的是浏览器请求了服务器A的某个页面,在操作该页面时,发送了一个请求B服务器的资源,这种现象就叫做跨域。
如何更详细的判定是否跨域呢?
当协议(http/https),端口或域名中有任何一个不同时,就视为跨域了。
为什么要进行跨域?
浏览器针对跨域设置了一个策略叫同源策略:原则上只允许请求同一个服务器的资源。注意,静态资源不受跨域限制,静态资源就是不会改变的资源,如图片,CSS文件,JS文件等。
利用JSONP进行跨域
jsonp跨域利用的是script标签无视同源策略并且还能执行代码的特定。需要注意的是,该方法需要接口返回的是一个函数的执行才可以。比如:
这里echo的就是一个函数的执行,callbackname是函数名。
具体的封装跨域函数代码如下:
function jsonp(url, data, callback) { 参数分别是请求的域名,query和回调函数
var str = "";
for (var i in data) {
str += i + "=" + data[i] + "&";
}
str = str.slice(0, -1);
window[data.callbackname] = callback;
var script = document.createElement("script");
script.src = url +"?"+str;
document.body.appendChild(script);
script.onload = function(){
script.remove()
delete window[data.callbackname];
}
}