Ant?Design_Form表單上傳文件組件實(shí)現(xiàn)詳解
背景
需要實(shí)現(xiàn)的需求:在一個(gè)表單提交中,需要提交各種組件的提交信息,其中包括上傳文件;一般呢,我們會(huì)在選擇文件的時(shí)候?qū)⑽募葌鞯椒?wù)器,拿到文件的URL,在提交表單的時(shí)候傳的其實(shí)是文件的URL;
剛開始,對(duì)文件沒有必填的校驗(yàn),是比較簡(jiǎn)單的;但是后來要求文件是必傳的,需要加上文件的校驗(yàn),就暴漏了一些小問題;
實(shí)現(xiàn)
首先,先對(duì)Upload組件加上必傳的校驗(yàn)
rules={[{ required: true, message: "請(qǐng)上傳文件" }]},
直接添加required校驗(yàn),肯定是不行的,我們需要自定義文件的校驗(yàn);
dom結(jié)構(gòu)大體是這樣:
<Item label="上傳文件" name="file" rules={[{ required: true, validator: checkFile }]}>
<Upload {...uploadProps}>
<div className="upload-content">
{imgUrl ? (
<div className="upload-cover">
<img src={imgUrl} />
</div>
) : (
<div className="upload-btn">{imgLoading ? <LoadingOutlined /> : <PlusOutlined />}</div>
)}
</div>
</Upload>
</Item>
校驗(yàn):
const checkFile = (rule: any, value: any) => {
if (!value) {
return Promise.reject("請(qǐng)上傳文件");
}
return Promise.resolve();
};
問題1:
warning.js:6 Warning: [antd: Upload] value is not a valid prop, do you mean fileList?
但是控制臺(tái)報(bào)錯(cuò):
warning.js:6 Warning: [antd: Upload] value is not a valid prop, do you mean fileList?
按照指示:在Item組件上加上:valuePropName="fileList",發(fā)現(xiàn)控制臺(tái)的報(bào)錯(cuò)確實(shí)沒有了;
但是新的問題來了,當(dāng)我們上傳文件的時(shí)候,畫面直接崩了??!
問題2:
Uncaught TypeError: (fileList || []).forEach is not a function
參照官網(wǎng):ant.design/components/…
在Item組件上添加getValueFromEvent事件;
<Item
label="上傳文件"
name="file"
valuePropName="fileList"
rules={[{ required: true, validator: checkFile }]}
getValueFromEvent={normFile}
>
const normFile = (e: any) => {
if (Array.isArray(e)) {
return e;
}
return e?.fileList;
};
最后效果:

tip1:注意一下新增和修改時(shí)校驗(yàn)方法
這時(shí)候校驗(yàn)是沒問題了,但是,如果你和我一樣,新增的提交和編輯的提交公用的時(shí)候,這一塊校驗(yàn)還是會(huì)有問題;編輯內(nèi)容的時(shí)候我們拿到的是文件的URL地址,不是文件對(duì)象,那么校驗(yàn)就會(huì)一直過不去;
所以校驗(yàn)方法就需要改一下,判斷條件也要加上URL,這一塊就不貼代碼了~
tip2: 注意一下beforeUpload的返回值
這里順道提一下,ant design 中如果不想走默認(rèn)的上傳,就可以beforeUpload身上做文章了,但是一定要注意攔截默認(rèn)上傳的條件是:
若返回 false 則停止上傳。支持返回一個(gè) Promise 對(duì)象,Promise 對(duì)象 reject 時(shí)則停止上傳
因?yàn)槲以谶@個(gè)方法開始的時(shí)候?qū)ξ募拇笮∵M(jìn)行了限制,如果不滿足就終止,但是,習(xí)慣性的寫成了return;這時(shí)候并沒有阻止默認(rèn)上傳的行為;需要改寫為return false;
以上就是Ant Design_Form表單上傳文件組件實(shí)現(xiàn)詳解的詳細(xì)內(nèi)容,更多關(guān)于Ant Design_Form表單上傳文件組件的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
默認(rèn)瀏覽器設(shè)置及vue自動(dòng)打開頁(yè)面的方法
今天小編就為大家分享一篇默認(rèn)瀏覽器設(shè)置及vue自動(dòng)打開頁(yè)面的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09
如何在vue項(xiàng)目中嵌入jsp頁(yè)面的方法(2種)
這篇文章主要介紹了如何在vue項(xiàng)目中嵌入jsp頁(yè)面的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
關(guān)于vue中計(jì)算屬性computed的詳細(xì)講解
computed是vue的配置選項(xiàng),它的值是一個(gè)對(duì)象,其中可定義多個(gè)計(jì)算屬性,每個(gè)計(jì)算屬性就是一個(gè)函數(shù),下面這篇文章主要給大家介紹了關(guān)于vue中計(jì)算屬性computed的詳細(xì)講解,需要的朋友可以參考下2022-07-07
vue一步到位的實(shí)現(xiàn)動(dòng)態(tài)路由
這篇文章主要介紹了vue一步到位的實(shí)現(xiàn)動(dòng)態(tài)路由,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06
vue導(dǎo)入excel文件,vue導(dǎo)入多個(gè)sheets的方式
這篇文章主要介紹了vue導(dǎo)入excel文件,vue導(dǎo)入多個(gè)sheets的方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
vue2.0 中使用transition實(shí)現(xiàn)動(dòng)畫效果使用心得
這篇文章主要介紹了vue2.0 中使用transition實(shí)現(xiàn)動(dòng)畫效果使用心得,本文通過案例知識(shí)給大家介紹的非常詳細(xì),需要的朋友參考下吧2018-08-08
vue組件實(shí)現(xiàn)移動(dòng)端九宮格轉(zhuǎn)盤抽獎(jiǎng)
這篇文章主要為大家詳細(xì)介紹了vue組件實(shí)現(xiàn)移動(dòng)端九宮格轉(zhuǎn)盤抽獎(jiǎng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-10-10

