跨域请求之JSONP

跨域恳求的方法有很多种,

1,iframe

2,document.domain

3,window.name

4,script

5,XDomainRequest (IE8+)

6,XMLHTTPRequest (Firefox3.5+)

7,postMessage (HTML5)

8,后台代理

...

它们有各自的优缺点,回来的数据格局也各不同,应根据需要慎重挑选。比方iframe回来html片段就对比适合,费老劲用它回来JSON就因小失大了。这篇开端我将打造一个有用的跨域恳求东西Sjax。运用script恳求的最大缺点,挑战是过错处理。比方404过错,它不象XMLHTTPRequest能精确的回来状况码404。我把这个放在最终一篇。


本系列首要描绘以上列举的方法4,即通过script回来JSON格局数据数据。这种方法如今称为JSONP。JSON是目前前后台交流运用最盛行,也最广泛的格局之一。相对于前期的AJAX回来XML(AJAX中的X即是XML),JSON显得更轻量级,没有剩余的Tag符号,解析也是原生的。XML回来到前端后先转成文档,通过DOM API一层层的解析。解析DOM是开支对比大的,尤其在前期的IE版别中(IE6/7/8),core js与dom交流的价值是很大的。


JSONP的实现思路很简单

1, 前端创立script符号,设置src,添加到head中(你可以往body中添加)。

2, 后台回来一个js变量jsonp,这个jsonp即是恳求后的JSON数据。

3, 回调完成后删去script符号(还有一些整理作业如防止有些浏览器内存泄露等)。


接口

Sjax.load(

    url,// 跨过恳求的URL

    success, // 回调函数,有必要界说一个形参,用于接纳后台回来的全局变量jsonp (约好后台回来如jsonp = {...}结构)

    timestamp,// 传true会加一个时间戳,防止缓存,默许不加

);

   

 

 

     

   

sjax_0.1.js by snandy

   

 

    function clk(){

        Sjax.load(

            'http://lf.yunnanw.cn/', 

            'http://www.lcsyt.com/', 

            'http://www.minnan888.net/', 

            'http://www.vipfuxin.com/', 

            'http://www.qclchina.com/', 

            'http://www.tongxinglong.com/', 

            'http://www.jinanwuliangye.com/', 

            '', 

            function(){

                document.getElementById('p1').innerHTML = 'Hi, ' + jsonp.name;

            }

        );      

    }

    


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29653106/viewspace-1183971/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/29653106/viewspace-1183971/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值