如何使用JQuery AJAX同時傳輸FormData和字串資料?

Susan Sarandon
發布: 2024-10-22 14:27:02
原創
584 人瀏覽過

How to Simultaneously Transmit FormData and String Data Using JQuery AJAX?

使用JQuery AJAX 同時傳輸FormData 和字串資料

要使用FormData() 傳送檔案和字串資料,請考慮以下方法字串資料:

建立一個新的FormData 物件:

<code class="javascript">var fd = new FormData();</code>
登入後複製

對於多個文件,從文件輸入中檢索選定的文件:

<code class="javascript">var file_data = $('input[type="file"]')[0].files;</code>
登入後複製

循環遍歷文件並追加使用每個檔案的唯一名稱將它們新增至FormData:

<code class="javascript">for(var i = 0;i<file_data.length;i++){
    fd.append("file_"+i, file_data[i]);
}</code>
登入後複製

接下來,使用jQuery 的.serializeArray() 擷取非檔案輸入資料:

<code class="javascript">var other_data = $('form').serializeArray();</code>
登入後複製

迭代非檔案- 檔案輸入資料並使用.append() 將其附加到FormData:

<code class="javascript">$.each(other_data,function(key,input){
    fd.append(input.name,input.value);
});</code>
登入後複製

最後,使用FormData 作為資料負載配置AJAX 請求:

<code class="javascript">$.ajax({
    url: 'test.php',
    data: fd,
    contentType: false,
    processData: false,
    type: 'POST',
    success: function(data){
        console.log(data);
    }
});</code>
登入後複製

透過以下方式透過這些步驟,您可以透過FormData 和JQuery AJAX 有效地同時傳送檔案和字串數據,確保所有必要的資訊都傳輸到伺服器。

以上是如何使用JQuery AJAX同時傳輸FormData和字串資料?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!