之前在面试的时候常常遇到问关于跨域的事儿,因此本身对跨域有必定的概念性了解,知道什么是跨域以及解决跨域的方法,可是具体实际历来没有操做过,直到最近在公司项目中,遇到了一个须要使iframe跨域进行POST提交的实际案例,我才明白具体如何使用iframe进行跨域操做。html
说到跨域,就不得不提起浏览器的同源策略。面试
同源策略限制从一个源加载的文档或脚本如何与来自另外一个源的资源进行交互。跨域
若是协议,端口(若是指定了一个)和主机对于两个页面是相同的,那么这两个页面就具备相同的源。浏览器
从这个定义能够看出,若是两个页面的协议,端口,主机三个只要有一个不同,就是不一样的源,想要相互之间进行交互,就须要进行跨域。dom
跨域的方法有不少,像JSONP、iframe、CORS、postMessage等等,因为项目中用到了iframe进行POST跨域,因此本文主要总结一下如何利用iframe进行POST无刷新提交。函数
咱们知道通常提交使用form表单进行提交,可是这种提交会致使页面跳转,因此交互效果不是友好,为了实现无刷新提交,咱们会使用Ajax,可是此时可能会出现一个问题----跨域,那么如何解决这个问题呢,可使用一个隐藏的iframe,咱们将要提交的数据提交到这个隐藏的iframe,而后让这个iframe去跳转,这样就能够在视觉上实现页面无跳转刷新(实际上页面仍是跳转了,只是iframe被隐藏,咱们看不到)。post
在提交后咱们还要获取到后台给咱们返回回来的数据,因此须要在iframe中进行数据的交互同时拿到返回回来的data
。ui
为了让数据能够顺利的进行数据交互,咱们一般使用document.domain
将域设置到顶级域。code
为了拿到返回回来的data
,须要使用一个函数,函数名后台已经告知。orm
因此整个实现代码以下:
<form action="You POST Link" method="post" target="target" id="J_commenting"> <select name="category" class="select J_filter" id="J_typeFilter"> <option value="0" selected="selected">Select Category</option> <option value="1">Life</option> <option value="2">People</option> <option value="3">Landscape</option> <option value="4">Tech</option> <option value="5">Others</option> </select> <input name="title" type="text" class="misstion-title J_misstion-title"> <textarea name="desc" class="misstion-description J_description" maxlength="200"></textarea> <button class="button J_button" type="submit">Submit</button> </form> <iframe name="target" style="display:none;"></iframe>
var $button = $('.J_button'); var $commenting = $('#J_commenting'); var $filter = $('.J_filter'); var $misstionTitle = $('.J_misstion-title'); var $description = $('.J_description'); $button.on('click', function () { var filterValue = $filter.val(); var misstionTitleValue = $misstionTitle.val(); var descriptionValue = $description.val(); if (filterValue === '0' || misstionTitleValue === '' || descriptionValue === '') { alert('Check if you filled out all the fields required'); } else { $commenting.submit(); } }); $commenting.on('submit', function () { document.domain = 'aa.com'; window.addData = function (data) { var dataCode = data.code; var dataMsg = data.message; if (dataCode === 0) { alert('submit success!'); } else { alert('submit failed!'); } } });
点击提交后,后台返回的数据:
document.domain = "aa.com"; var data = {"code":-2,"info":"please login first","message":"please login first"}; if( typeof(parent.window['addData']) == "function"){ parent.window['addData'](data); }else if( typeof(window.top['addData']) == "function"){ window.top['addData'](data); }