欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Ant?Design_Form表單上傳文件組件實現(xiàn)詳解

 更新時間:2023年03月07日 14:31:15   作者:coffee  
這篇文章主要為大家介紹了Ant?Design_Form表單上傳文件組件實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

背景

需要實現(xiàn)的需求:在一個表單提交中,需要提交各種組件的提交信息,其中包括上傳文件;一般呢,我們會在選擇文件的時候?qū)⑽募葌鞯椒掌?,拿到文件的URL,在提交表單的時候傳的其實是文件的URL;

剛開始,對文件沒有必填的校驗,是比較簡單的;但是后來要求文件是必傳的,需要加上文件的校驗,就暴漏了一些小問題;

實現(xiàn)

首先,先對Upload組件加上必傳的校驗

rules={[{ required: true, message: "請上傳文件" }]},

直接添加required校驗,肯定是不行的,我們需要自定義文件的校驗;

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>

校驗:

const checkFile = (rule: any, value: any) => {
    if (!value) {
            return Promise.reject("請上傳文件");
    }
    return Promise.resolve();
};

問題1:

warning.js:6 Warning: [antd: Upload] value is not a valid prop, do you mean fileList?

但是控制臺報錯:

warning.js:6 Warning: [antd: Upload] value is not a valid prop, do you mean fileList?

按照指示:在Item組件上加上:valuePropName="fileList",發(fā)現(xiàn)控制臺的報錯確實沒有了;

但是新的問題來了,當我們上傳文件的時候,畫面直接崩了??!

問題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:注意一下新增和修改時校驗方法

這時候校驗是沒問題了,但是,如果你和我一樣,新增的提交和編輯的提交公用的時候,這一塊校驗還是會有問題;編輯內(nèi)容的時候我們拿到的是文件的URL地址,不是文件對象,那么校驗就會一直過不去;

所以校驗方法就需要改一下,判斷條件也要加上URL,這一塊就不貼代碼了~

tip2: 注意一下beforeUpload的返回值

這里順道提一下,ant design 中如果不想走默認的上傳,就可以beforeUpload身上做文章了,但是一定要注意攔截默認上傳的條件是:

若返回 false 則停止上傳。支持返回一個 Promise 對象,Promise 對象 reject 時則停止上傳

因為我在這個方法開始的時候?qū)ξ募拇笮∵M行了限制,如果不滿足就終止,但是,習慣性的寫成了return;這時候并沒有阻止默認上傳的行為;需要改寫為return false;

以上就是Ant Design_Form表單上傳文件組件實現(xiàn)詳解的詳細內(nèi)容,更多關于Ant Design_Form表單上傳文件組件的資料請關注腳本之家其它相關文章!

相關文章

  • vue插件及修改ip啟動端口解析

    vue插件及修改ip啟動端口解析

    這篇文章主要為大家介紹了vue插件及修改ip啟動端口的解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪
    2022-04-04
  • Vue用v-for給循環(huán)標簽自身屬性添加屬性值的方法

    Vue用v-for給循環(huán)標簽自身屬性添加屬性值的方法

    這篇文章主要介紹了Vue用v-for給循環(huán)標簽自身屬性添加屬性值的方法,文中大家給大家列舉了三種方法 ,需要的朋友可以參考下
    2018-10-10
  • Vue用v-for給src屬性賦值的方法

    Vue用v-for給src屬性賦值的方法

    下面小編就為大家分享一篇Vue用v-for給src屬性賦值的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • Vue全局共享數(shù)據(jù)之globalData,vuex,本地存儲的使用

    Vue全局共享數(shù)據(jù)之globalData,vuex,本地存儲的使用

    這篇文章主要介紹了Vue全局共享數(shù)據(jù)之globalData,vuex,本地存儲的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue通過style或者class改變樣式的實例代碼

    vue通過style或者class改變樣式的實例代碼

    這篇文章主要介紹了vue通過style或者class改變樣式的實例代碼,在文中給大家提到了vue的一些樣式(class/style)綁定,需要的朋友可以參考下
    2018-10-10
  • 如何查看vue-cli版本的兩個命令

    如何查看vue-cli版本的兩個命令

    這篇文章主要介紹了如何查看vue-cli版本的兩個命令問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • Vue生命周期詳解

    Vue生命周期詳解

    這篇文章詳細介紹了Vue的生命周期,文中通過代碼示例介紹的非常詳細。對大家的學習有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • Vue源碼解析之Template轉(zhuǎn)化為AST的實現(xiàn)方法

    Vue源碼解析之Template轉(zhuǎn)化為AST的實現(xiàn)方法

    這篇文章主要介紹了Vue源碼解析之Template轉(zhuǎn)化為AST的實現(xiàn)方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • Vue的子父組件傳值之小白必看篇

    Vue的子父組件傳值之小白必看篇

    這篇文章主要介紹了Vue的子父組件傳值之小白必看篇,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue中實現(xiàn)移動端的scroll滾動方法

    vue中實現(xiàn)移動端的scroll滾動方法

    下面小編就為大家分享一篇vue中實現(xiàn)移動端的scroll滾動方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03

最新評論