溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用iframe怎么實現跨域POST提交

發布時間:2021-04-09 17:14:57 來源:億速云 閱讀:431 作者:Leah 欄目:web開發

今天就跟大家聊聊有關使用iframe怎么實現跨域POST提交,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

iframe跨域POST無刷新提交

跨域的方法有很多,像JSONP、iframe、CORS、postMessage等等,由于項目中用到了iframe進行POST跨域,所以本文主要總結一下如何利用iframe進行POST無刷新提交。

我們知道一般提交使用form表單進行提交,但是這種提交會導致頁面跳轉,所以交互效果不是友好,為了實現無刷新提交,我們會使用Ajax,但是此時可能會出現一個問題—-跨域,那么如何解決這個問題呢,可以使用一個隱藏的iframe,我們將要提交的數據提交到這個隱藏的iframe,然后讓這個iframe去跳轉,這樣就可以在視覺上實現頁面無跳轉刷新(實際上頁面還是跳轉了,只是iframe被隱藏,我們看不到)。

在提交后我們還要獲取到后臺給我們返回回來的數據,所以需要在iframe中進行數據的交互同時拿到返回回來的data。

為了讓數據可以順利的進行數據交互,我們通常使用document.domain將域設置到頂級域。
為了拿到返回回來的data,需要使用一個函數,函數名后臺已經告知。

附實現代碼

<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" ></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);
}

看完上述內容,你們對使用iframe怎么實現跨域POST提交有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女