国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > 一、input上傳文件詳解

一、input上傳文件詳解

來(lái)源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-11-22 22:54:47 1700664887

1. input上傳文件保存

input標(biāo)簽有個(gè)type為file,用于選擇上傳文件。在提交表單時(shí)需要注意enctype屬性設(shè)置為multipart/form-data。接收文件的后端可以通過(guò)request.FILES.get('file')來(lái)拿到上傳的文件對(duì)象。

{% csrf_token %}

2. input上傳文件第二次獲取不到

由于input的type為file,每次選擇完文件后會(huì)在網(wǎng)頁(yè)上留下緩存,因此如果用戶(hù)再次選擇同一個(gè)文件上傳,后端是獲取不到文件對(duì)象的。因此,需要在input標(biāo)簽中添加一個(gè)自定義的屬性,讓每次選擇文件時(shí)都能創(chuàng)建新的input標(biāo)簽。





3. input上傳文件夾

目前還沒(méi)有原生的input組件支持上傳文件夾,但是可以借助一些插件實(shí)現(xiàn)上傳文件夾的功能,比如WebUploader,F(xiàn)ine uploader等。

4. input上傳文件完成

上傳文件完成后,可以在前端根據(jù)后端返回的數(shù)據(jù)進(jìn)行提示。比如可以在頁(yè)面上顯示上傳成功或上傳失敗的狀態(tài)。

$.ajax({
  url: '/upload/',
  type: 'POST',
  data: formdata,
  processData: false,
  contentType: false,
  success: function(data) {
    alert('上傳成功');
  },
  error: function(data) {
    alert('上傳失敗');
  }
});

5. input上傳文件修改按鈕名字

可以修改input上傳文件按鈕的名字,修改后的名字會(huì)顯示在選擇文件的按鈕上。


二、input多文件上傳

1. input多文件上傳

在input標(biāo)簽上添加multiple屬性,即可實(shí)現(xiàn)多文件上傳功能。


2. input上傳文件重復(fù)上傳失敗

由于每個(gè)上傳的文件都有唯一的文件名,因此如果上傳的文件名相同則會(huì)上傳失敗。可以在前端對(duì)文件名進(jìn)行處理,使其在后端不會(huì)重復(fù)。




3. input上傳文件時(shí)無(wú)法選擇文件

出現(xiàn)這種情況一般是因?yàn)闉g覽器禁止訪(fǎng)問(wèn)本地文件,可以嘗試更換瀏覽器或者檢查瀏覽器設(shè)置。

三、input上傳文件獲取文件上傳路徑

1. input上傳文件獲取文件上傳路徑

input上傳文件的path屬性是只讀的,無(wú)法通過(guò)JavaScript獲取。




2. input上傳文件怎么知道上傳完成

上傳文件完成后,后端會(huì)返回上傳文件的信息,前端可以根據(jù)這些信息判斷上傳是否成功。

$.ajax({
  url: '/upload/',
  type: 'POST',
  data: formdata,
  processData: false,
  contentType: false,
  success: function(data) {
    if (data.code === 0) {
      alert('上傳成功');
    } else {
      alert('上傳失敗');
    }
  },
  error: function(data) {
    alert('上傳失敗');
  }
});

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專(zhuān)屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
Vue2轉(zhuǎn)Vue3全面總結(jié)

本篇文章旨在介紹Vue2到Vue3的轉(zhuǎn)化過(guò)程,并從多個(gè)角度進(jìn)行詳細(xì)闡述。一、Vue2和Vue3有哪些不同點(diǎn)?Vue2和Vue3的不同點(diǎn)主要體現(xiàn)在以下幾個(gè)方面:...詳情>>

2023-11-22 23:45:12
Uniapp點(diǎn)擊事件全解析

Uniapp是一個(gè)跨平臺(tái)的框架,開(kāi)發(fā)者可以通過(guò)一份代碼適配多個(gè)移動(dòng)平臺(tái),包括iOS、Android、H5、小程序等。其中,點(diǎn)擊事件作為移動(dòng)應(yīng)用中常見(jiàn)的交...詳情>>

2023-11-22 23:23:36
byte轉(zhuǎn)string詳解

byte轉(zhuǎn)string是編程中經(jīng)常遇到的一個(gè)操作。無(wú)論是在文件處理、網(wǎng)絡(luò)傳輸還是數(shù)據(jù)存儲(chǔ)上,都需要將byte轉(zhuǎn)為string進(jìn)行處理。本文將從多個(gè)方面詳解...詳情>>

2023-11-22 23:16:23
C++ sort頭文件詳解

一、sort頭文件介紹C++ sort頭文件是C++標(biāo)準(zhǔn)庫(kù)中的一個(gè)重要頭文件,用來(lái)排序(主要是升序)數(shù)組或序列。通過(guò)對(duì)sort函數(shù)的調(diào)用,C++ sort頭文件...詳情>>

2023-11-22 22:15:11
如何清除svchost病毒

一、了解svchost病毒svchost病毒是一種比較常見(jiàn)的惡意軟件,它通過(guò)偽裝成系統(tǒng)進(jìn)程的方式進(jìn)行隱藏,進(jìn)而竊取用戶(hù)的個(gè)人信息和系統(tǒng)信息。而且svch...詳情>>

2023-11-22 22:04:23