在ant form中上傳圖片

背景

最近做勇泰商城項(xiàng)目空幻,用了之前沒(méi)用過(guò)的react和ant-design幌墓,其余部分大同小異贬循,結(jié)果要在表單里上傳圖片缺犯了難句柠,網(wǎng)上找了一圈也沒(méi)有找到靠譜的解決方案浦译,遂在這里記錄一番

動(dòng)手

樣式

先來(lái)一個(gè)form組件,然后再form的item里加入upload組件

<Form onFinish={onFinish} form={form}>
    <Form.Item
    label="商品圖片"
    name="img"
    valuePropName="img"
    getValueFromEvent={normFile}
    >
    <Upload
        name="file"
        listType="picture-card"
        className="avatar-uploader"
        action="https://upload.qiniup.com"
        showUploadList={false}
        data={getToken}
        onChange={handleChange}
    >
        {form.getFieldValue("img") ? (
        <img className="img"  src={baseURL + form.getFieldValue("img")} alt="" />
        ) : (
        <div>
            <div style={{ marginTop: 8 }}>Upload</div>
        </div>
        )}
    </Upload>
    </Form.Item>
    <Form.Item>
    <Space size="middle">
        <Button type="primary" htmlType="submit">
        提交
        </Button>
        <Button
        onClick={() => {
            form.resetFields();
            setVisible(false);
        }}
        >
        取消
        </Button>
    </Space>
    </Form.Item>
</Form>

使用form組件的關(guān)聯(lián)屬性form溯职,組件渲染時(shí)使用form.getFieldValue("img")檢測(cè)form中是否有相關(guān)的值,此時(shí)存儲(chǔ)的值并不是像往常那樣的圖片本地地址精盅,而是上傳后的圖片hash值,若有值缸榄,就拼接baserUrl展示圖片

<img className="img"  src={baseURL + form.getFieldValue("img")} alt="" />

如果沒(méi)有值的話就顯示上傳按鈕

<div>
    <div style={{ marginTop: 8 }}>Upload</div>
</div>

圖片上傳完后如何將值回填到form表單中

這就需要用到Form.Item的屬性getValueFromEvent,官方文檔給的描述是“設(shè)置如何將 event 的值轉(zhuǎn)換成字段值”渤弛,說(shuō)實(shí)話,看了好幾遍甚带,沒(méi)明白她肯,還好找到了一段示例代碼,最后勉強(qiáng)明白鹰贵,應(yīng)該是會(huì)捕捉內(nèi)部元素觸發(fā)的回調(diào)晴氨,內(nèi)部的upload組件文件狀態(tài)改變時(shí)會(huì)有一個(gè)回調(diào),參見(jiàn)onChange碉输。Form.Item捕捉到這個(gè)回調(diào)籽前,我們就可以在里面搞些事情拿到上傳后的hash值了,如代碼中的getValueFromEvent={normFile}

const normFile = (info) => {
    if (info.file.status == "done") {
      return info.file.response.key;
    }
  };

上述代碼種增加了一步info.file.status=="done"的判斷敷钾,因?yàn)槟玫降氖录俏募顟B(tài)改變的回調(diào)枝哄,所以只有最后上傳完成的一次回調(diào)中會(huì)帶有返回的hash值。

修改數(shù)據(jù)如何將hash值又轉(zhuǎn)換成圖片顯示出來(lái)

做CURD的都知道阻荒,一個(gè)表單一般創(chuàng)建和更新共用挠锥,剛才解決了創(chuàng)建的問(wèn)題。其實(shí)更新的問(wèn)題在上文中已經(jīng)說(shuō)過(guò)了侨赡,其實(shí)就是使用form.getFieldValue("img")蓖租,很簡(jiǎn)單,問(wèn)題迎刃而解羊壹。

總結(jié)

之所以遇到這個(gè)問(wèn)題其實(shí)是對(duì)新技術(shù)的不熟悉蓖宦,等熟悉了之后也覺(jué)得這個(gè)問(wèn)題沒(méi)什么了。程序開(kāi)發(fā)人員寫(xiě)的文檔往往如此油猫,自己心理跟明鏡似的稠茂,所以文檔寫(xiě)的非常簡(jiǎn)單,但不熟悉的人來(lái)看文檔的話情妖,就非常吃力了主慰,要銘記此事嚣州,常自省也。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末共螺,一起剝皮案震驚了整個(gè)濱河市该肴,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌藐不,老刑警劉巖匀哄,帶你破解...
    沈念sama閱讀 211,639評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異雏蛮,居然都是意外死亡涎嚼,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)挑秉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)法梯,“玉大人,你說(shuō)我怎么就攤上這事犀概×⒀疲” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,221評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵姻灶,是天一觀的道長(zhǎng)铛绰。 經(jīng)常有香客問(wèn)我,道長(zhǎng)产喉,這世上最難降的妖魔是什么捂掰? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,474評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮曾沈,結(jié)果婚禮上这嚣,老公的妹妹穿的比我還像新娘。我一直安慰自己塞俱,他們只是感情好姐帚,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著敛腌,像睡著了一般卧土。 火紅的嫁衣襯著肌膚如雪惫皱。 梳的紋絲不亂的頭發(fā)上像樊,一...
    開(kāi)封第一講書(shū)人閱讀 49,816評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音旅敷,去河邊找鬼生棍。 笑死,一個(gè)胖子當(dāng)著我的面吹牛媳谁,可吹牛的內(nèi)容都是我干的涂滴。 我是一名探鬼主播友酱,決...
    沈念sama閱讀 38,957評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼柔纵!你這毒婦竟也來(lái)了缔杉?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,718評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤搁料,失蹤者是張志新(化名)和其女友劉穎或详,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體郭计,經(jīng)...
    沈念sama閱讀 44,176評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡霸琴,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了昭伸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片梧乘。...
    茶點(diǎn)故事閱讀 38,646評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖庐杨,靈堂內(nèi)的尸體忽然破棺而出选调,到底是詐尸還是另有隱情,我是刑警寧澤辑莫,帶...
    沈念sama閱讀 34,322評(píng)論 4 330
  • 正文 年R本政府宣布学歧,位于F島的核電站,受9級(jí)特大地震影響各吨,放射性物質(zhì)發(fā)生泄漏枝笨。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評(píng)論 3 313
  • 文/蒙蒙 一揭蜒、第九天 我趴在偏房一處隱蔽的房頂上張望横浑。 院中可真熱鬧,春花似錦屉更、人聲如沸徙融。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,755評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)欺冀。三九已至,卻和暖如春萨脑,著一層夾襖步出監(jiān)牢的瞬間隐轩,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,987評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工渤早, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留职车,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,358評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像悴灵,于是被迫代替她去往敵國(guó)和親扛芽。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評(píng)論 2 348

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