FormData多文件上傳

問(wèn)題:jquery Ajax serialize()表單進(jìn)行序列化方式上傳文件

通過(guò)$(‘#example’).serialize()可以對(duì)form表單進(jìn)行序列化,從而將form表單中的所有參數(shù)傳遞到服務(wù)端孕豹,只能傳遞一般的參數(shù)猎提,上傳文件的文件流是無(wú)法被序列化并傳遞的唇跨。

不過(guò)如今主流瀏覽器都開始支持一個(gè)叫做FormData的對(duì)象适荣,有了這個(gè)FormData噪生,我們就可以輕松地使用Ajax方式進(jìn)行文件上傳了阵翎。


<html>
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
<form id="example">
    username: <input type="text" name="username"/><br/>
    password: <input type="password" name="password"/><br/>
    file: <input type="file" id="files" multiple/><br/>
    <input type="submit" value="提交"/>
</form>
<div id='file-list-display'></div>
<script type="text/javascript">
    $(function () {
        let fileList = [];
        const fileCatcher = $('#example');
        const files = $("#files");
        const fileListDisplay = $('#file-list-display');

        fileCatcher.on("submit", function (event) {
            event.preventDefault();
            //上傳文件
            let formData = new FormData(fileCatcher[0]);

            //循環(huán)添加到formData中
            fileList.forEach(function (file) {
                formData.append('files', file, file.name);
            })
            const request = new XMLHttpRequest();
            request.open("POST", "upload");
            request.send(formData);
        });

        files.on("change", function (event) {
            for (var i = 0; i < files[0].files.length; i++) {
                fileList.push(files[0].files[i]);
            }
            let content = '';
            fileList.forEach(function (file, index) {
                content += '<p>' + (index + 1) + ":" + file.name + '</p>';

            })
            fileListDisplay.html(content);
        });
    })
</script>
</body>
</html>

源碼

https://github.com/ncc0706/front-end/blob/master/form-data/form-data-2-jq.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末逢并,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子郭卫,更是在濱河造成了極大的恐慌砍聊,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,490評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件贰军,死亡現(xiàn)場(chǎng)離奇詭異玻蝌,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)词疼,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門俯树,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人贰盗,你說(shuō)我怎么就攤上這事许饿。” “怎么了舵盈?”我有些...
    開封第一講書人閱讀 165,830評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵陋率,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我秽晚,道長(zhǎng)瓦糟,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,957評(píng)論 1 295
  • 正文 為了忘掉前任赴蝇,我火速辦了婚禮菩浙,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己劲蜻,他們只是感情好陆淀,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評(píng)論 6 393
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著斋竞,像睡著了一般倔约。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上坝初,一...
    開封第一講書人閱讀 51,754評(píng)論 1 307
  • 那天浸剩,我揣著相機(jī)與錄音,去河邊找鬼鳄袍。 笑死绢要,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的拗小。 我是一名探鬼主播重罪,決...
    沈念sama閱讀 40,464評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼哀九!你這毒婦竟也來(lái)了剿配?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤阅束,失蹤者是張志新(化名)和其女友劉穎呼胚,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體息裸,經(jīng)...
    沈念sama閱讀 45,847評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蝇更,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評(píng)論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了呼盆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片年扩。...
    茶點(diǎn)故事閱讀 40,137評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖访圃,靈堂內(nèi)的尸體忽然破棺而出厨幻,到底是詐尸還是另有隱情,我是刑警寧澤腿时,帶...
    沈念sama閱讀 35,819評(píng)論 5 346
  • 正文 年R本政府宣布克胳,位于F島的核電站,受9級(jí)特大地震影響圈匆,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜捏雌,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評(píng)論 3 331
  • 文/蒙蒙 一跃赚、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦纬傲、人聲如沸满败。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)算墨。三九已至,卻和暖如春汁雷,著一層夾襖步出監(jiān)牢的瞬間净嘀,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工侠讯, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留挖藏,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,409評(píng)論 3 373
  • 正文 我出身青樓厢漩,卻偏偏與公主長(zhǎng)得像膜眠,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子溜嗜,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容