Maison >interface Web >js tutoriel >Problèmes inter-domaines JavaScript
Le contenu partagé avec vous dans cet article est le problème inter-domaines de JavaScript, qui a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer
1jsonp
Les interfaces générales utilisent jsonp. cross-domain , utilisez l'ajax de jquery pour spécifier le dataType comme jsonp
$.ajax({ async : true, url : "https://api.douban.com/v2/book/search", type : "GET", dataType : "jsonp", // 返回的数据类型,设置为JSONP方式 jsonp : 'callback', //指定一个查询参数名称来覆盖默认的 jsonp 回调参数名 callback jsonpCallback: 'handleResponse', //设置回调函数名 data : { q : "javascript", count : 1 }, success: function(response, status, xhr){ console.log('状态为:' + status + ',状态是:' + xhr.statusText); console.log(response); } });
Le principe de jsonp prenant en charge le cross-domain : Le principe de JSONP pour implémenter les requêtes inter-domaines est simplement de créer dynamiquement le 7d74a74545caf71c943c5e772a9958be n'est pas soumis à la politique de même origine pour obtenir des données sur tous les domaines.
est en fait l'implémentation du code suivant : le script js renvoie callback(data), et une fonction de rappel est définie dans la page
<script type="text/javascript"> function handleResponse(response){ console.log(response); } </script> <script type="text/javascript"> window.onload = function() { var oBtn = document.getElementById('btn'); oBtn.onclick = function() { var script = document.createElement("script"); script.src = "https://api.douban.com/v2/book/search?q=javascript&count=1&callback=handleResponse"; document.body.insertBefore(script, document.body.firstChild); }; }; </script>
2iframe + form est compatible avec Navigateur IE, iframe Le contenu du corps correspond aux données à utiliser
<iframe name='hidden_frame' id="hidden_frame" style='display:none'></iframe> <form id="fileform" method="post" enctype="multipart/form-data" target="hidden_frame"> <input type="file" name="fileUpload" /> </form> <button id="submitbtn">开始上传</button> <script type="text/javascript"> function callback(msg) { //回调函数 alert(msg); } </script> <script type="text/javascript"> $("#submitbtn").click(function() { var callbackurl = window.location.href.substring(0, window.location.href.lastIndexOf('/')) + "proxy.html"; //获取代理文件路径 $("#fileform").attr("action", "FileHandler.ashx?callbackurl=" + callbackurl); $("#fileform").submit(); }) </script>
Méthode postMessage() de 3H5, la compatibilité n'est pas si bonne
Pour plus de détails, voir https://www.cnblogs .com/dolphinX/p/3464056.html
Téléchargez le code de l'image, les données renvoyées par l'interface sont la méthode d'écriture de postMessage
<form action='http://bird.sns.iqiyi.com/group_photo/upload' method="post" target="imgFile" id="fileinfo" enctype="multipart/form-data"> <input type="file" id="imgFile" accept="image/gif, image/png" class="hide" onchange="getPhotoSize(this)" /> <input type="hidden" name="name" value="" /> <input type="hidden" name="hobby" value="" /> </form> <iframe
<script type="text/javascript"> $(document).ready(function() { $('#upload').click(function() { $("#imgFile")[0].click(); }); }); var queryToJson = function(url) { url = url.replace(/#.*/, ""); var query = url.substr(url.lastIndexOf('?') + 1); var params = query.split('&'); var result = {}; for (var i = 0; i < params.length; i++) { var t = params[i].split("="); if (!t[0]) continue; result[decodeURIComponent(t[0])] = decodeURIComponent(t[1] || ""); } return result; }; $('[name=name]').val(queryToJson(window.location.href).name); $('[name=hobby]').val(queryToJson(window.location.href).hobby); //判断照片大小 function getPhotoSize(obj) { photoExt = obj.value.substr(obj.value.lastIndexOf(".")).toLowerCase(); //只支持jpg,png if (photoExt != '.jpg' && photoExt != '.png') { showMsg("请上传正确的图片格式,如JPEG、PNG"); return false; } var fileSize = 0; fileSize = obj.files[0].size; fileSize = Math.round(fileSize / 1024); //单位为KB if (fileSize >= 10000) { showMsg("建议上传图片不超过10M"); return false; } //跳转到过渡页,请求上传接口,将接口返回插入结果页src $('#page2').addClass('hide'); $('#imgFile').addClass('hide'); $('#fileinfo').submit(); $('#loading').removeClass('hide'); getMsg(); } //获取返回数据 function getMsg() { window.addEventListener('message', function(e) { $('#loading').addClass('hide'); if (e.source != window.parent) return; if (e.data.code == 'A00000') { $('#imgSrc')[0].src = e.data.data.url; $('#msg').html(e.data.data.message); $('#page5').removeClass('hide'); } else { location.href = '/anotherTry.html'; } }, false); } //显示提示信息 function showMsg(msg) { var _this = this; $('#msgTip').html(msg); $('#msgTip').removeClass('hide'); window.setTimeout(function() { $('#msgTip').addClass('hide'); }, 3000); } //再试一次 function tryAgain() { $('#fileinfo').submit(); $('#page5').addClass('hide'); //看不到加载页面,页面闪 $('#loading').removeClass('hide'); getMsg(); } </script>
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!