本文摘自 《JavaScript 設(shè)計(jì)模式》張容銘 著 版權(quán)歸原作者所有
- 端口、協(xié)議、域名、IP不一致都會(huì)產(chǎn)生跨域問(wèn)題。
1.站長(zhǎng)統(tǒng)計(jì)
// 利用img之類的標(biāo)簽通過(guò)src屬性可以向其他域下的服務(wù)器發(fā)送請(qǐng)求。
// 但是此類請(qǐng)求是get請(qǐng)求,而且是單向的,不會(huì)有響應(yīng)數(shù)據(jù)。
// 統(tǒng)計(jì)代理
var Count = (function(){
// 緩存圖片
var img = new Image();
// 返回統(tǒng)計(jì)函數(shù)
return function(param){``
// 統(tǒng)計(jì)請(qǐng)求字符串
var str = 'http://www.count.com/a.git?';
// 拼接請(qǐng)求字符串
for (var i in param){
str += i + '=' + param[i]
}
// 發(fā)送統(tǒng)計(jì)請(qǐng)求
_img.src = str
}
})();
Count({num:10})
2.JSONP(比較常用且常見(jiàn)的)
//利用script標(biāo)簽跨域。(CDN)
<script>
function jsonpCallBack(res,req){
console.log(res,req);
}
</script>
<scrtipt src="http://localhost/test/jsonp.php?callback=jsonp_CallBack&data=getJsonpData"></script>