¡¡¡¡(1).JSONP£º
¡¡¡¡ÔÀíÊÇ£º¶¯Ì¬²åÈëscript±êÇ©£¬Í¨¹ýscript±êÇ©ÒýÈëÒ»¸öjsÎļþ£¬Õâ¸öjsÎļþÔØÈë³É¹¦ºó»áÖ´ÐÐÎÒÃÇÔÚurl²ÎÊýÖÐÖ¸¶¨µÄº¯Êý£¬²¢ÇÒ»á°ÑÎÒÃÇÐèÒªµÄjsonÊý¾Ý×÷Ϊ²ÎÊý´«Èë¡£
¡¡¡¡ÓÉÓÚͬԴ²ßÂÔµÄÏÞÖÆ£¬XmlHttpRequestÖ»ÔÊÐíÇëÇóµ±Ç°Ô´(ÓòÃû¡¢ÐÒé¡¢¶Ë¿Ú)µÄ×ÊÔ´£¬ÎªÁËʵÏÖ¿çÓòÇëÇ󣬿ÉÒÔͨ¹ýscript±êǩʵÏÖ¿çÓòÇëÇó£¬È»ºóÔÚ·þÎñ¶ËÊä³öJSONÊý¾Ý²¢Ö´Ðлص÷º¯Êý£¬´Ó¶ø½â¾öÁË¿çÓòµÄÊý¾ÝÇëÇó¡£
¡¡¡¡ÓŵãÊǼæÈÝÐԺ㬼òµ¥Ò×Óã¬Ö§³Öä¯ÀÀÆ÷Óë·þÎñÆ÷Ë«ÏòͨÐÅ¡£È±µãÊÇÖ»Ö§³ÖGETÇëÇó¡£
¡¡¡¡JSONP£ºjson+padding(ÄÚÌî³ä)£¬¹ËÃû˼Ò壬¾ÍÊÇ°ÑJSONÌî³äµ½Ò»¸öºÐ×ÓÀï
¡¡¡¡javascript ´úÂë
- function createJs(sUrl){
- var oScript = document.createElement('script');
- oScript.type = 'text/javascript';
- oScript.src = sUrl;
- document.getElementsByTagName('head')[0].appendChild(oScript);
- }
- createJs('jsonp.js');
- box({
- 'name': 'test'
- });
- function box(json){
- alert(json.name);
- }
¡¡¡¡(2).CORS
¡¡¡¡·þÎñÆ÷¶Ë¶ÔÓÚCORSµÄÖ§³Ö£¬Ö÷Òª¾ÍÊÇͨ¹ýÉèÖÃAccess-Control-Allow-OriginÀ´½øÐеġ£Èç¹ûä¯ÀÀÆ÷¼ì²âµ½ÏàÓ¦µÄÉèÖ㬾ͿÉÒÔÔÊÐíAjax½øÐпçÓòµÄ·ÃÎÊ¡£
¡¡¡¡(3).ͨ¹ýÐÞ¸Ädocument.domainÀ´¿ç×ÓÓò
¡¡¡¡½«×ÓÓòºÍÖ÷ÓòµÄdocument.domainÉèΪͬһ¸öÖ÷Óò.Ç°ÌáÌõ¼þ£ºÕâÁ½¸öÓòÃû±ØÐëÊôÓÚͬһ¸ö»ù´¡ÓòÃû!¶øÇÒËùÓõÄÐÒ飬¶Ë¿Ú¶¼ÒªÒ»Ö£¬·ñÔòÎÞ·¨ÀûÓÃdocument.domain½øÐпçÓò
¡¡¡¡Ö÷ÓòÏàͬµÄʹÓÃdocument.domain
¡¡¡¡(4).ʹÓÃwindow.nameÀ´½øÐпçÓò
¡¡¡¡window¶ÔÏóÓиönameÊôÐÔ£¬¸ÃÊôÐÔÓиöÌØÕ÷£º¼´ÔÚÒ»¸ö´°¿Ú(window)µÄÉúÃüÖÜÆÚÄÚ,´°¿ÚÔØÈëµÄËùÓеÄÒ³Ã涼Êǹ²ÏíÒ»¸öwindow.nameµÄ£¬Ã¿¸öÒ³Ãæ¶Ôwindow.name¶¼ÓжÁдµÄȨÏÞ£¬window.nameÊdz־ôæÔÚÒ»¸ö´°¿ÚÔØÈë¹ýµÄËùÓÐÒ³ÃæÖеÄ
¡¡¡¡(5).ʹÓÃHTML5ÖÐÐÂÒý½øµÄwindow.postMessage·½·¨À´¿çÓò´«ËÍÊý¾Ý
¡¡¡¡»¹ÓÐflash¡¢ÔÚ·þÎñÆ÷ÉÏÉèÖôúÀíÒ³ÃæµÈ¿çÓò·½Ê½¡£¸öÈËÈÏΪwindow.nameµÄ·½·¨¼È²»¸´ÔÓ£¬Ò²ÄܼæÈݵ½¼¸ºõËùÓÐä¯ÀÀÆ÷£¬ÕâÕæÊǼ«ºÃµÄÒ»ÖÖ¿çÓò·½·¨¡£
תÔØÇë×¢Ã÷£º ÎÄÕÂתÔØ×Ô£º°®Ë¼×ÊÔ´Íø http://www.aseoe.com/show-12-921-1.html