input = file 实现上传文件

input = file 实现上传文件使用input=file实现文件上传功能,如果点击提交按钮,提交表单并上传选中的文件:<FormItemlabel=”上传简历”><divclassName=”section-pushInChannel-fileInput”><inputid=”file”onChange={this.handleFileChange}t…

大家好,又见面了,我是你们的朋友全栈君。

使用input = file实现文件上传功能, 如果点击提交按钮,提交表单并上传选中的文件:
在这里插入图片描述

<FormItem label="上传简历">
    <div className="section-pushInChannel-fileInput">
        <input id="file" onChange={this.handleFileChange} type="file"  name="file" multiple="multiple"></input>
        <div className="fileTip"></div>
    </div>
</FormItem>

handleFileChange = (e) => {
      const input = e.target;
       const files = e.target.files;
       if(files && files[0]) {
           const file = files[0];
           if(file.size > 1024 * 1024 *3) {
               fileTip.innerHTML = '文件大小不能超过3M!';
               input.value = '';
               return false;
           } else {
               fileTip.innerHTML = '';
               formData.append("file", file); 
           }
       }
    }

handleSubmitBtnClick = (e) => {
        const { form } = this.props;
        e.preventDefault();
        form.validateFields((err, values) => {
            if(!fileInput.value) {
                fileTip.innerHTML = '请选择您要上传的简历';
            }
            if(!err) {
                if(!fileInput.value) {
                    return;
                }
                Object.keys(values).forEach((key) => {
                    formData.append(key, values[key]);
                });
                axios.post('http://120.77.204.211:9091/api/push', formData).then(res => {
                    if(res.data.success && res.data.retCode === 0) {
                        // 成功
                        this.setState({
                            visible: true,
                        });
                        codeTip.innerHTML="";
                    } else {
                        // 失败
                        formData = new FormData(); // 每次失败要重置formdata对象
                        formData.append('file', fileInput.files[0]);
                        codeTip.innerHTML="您输入的验证码错误";
                    }
                })
            }
        })
    }

注意:

  1. 提交包含文件的表单时,需要使用FormData对象,将要提交的字段append,作为请求的参数;
  2. 可以通过fileInput.value来清空上传的文件;
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/160384.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 计算机逻辑与或非运算规则_与 或 非 三种逻辑符号计算机

    计算机逻辑与或非运算规则_与 或 非 三种逻辑符号计算机与&&或||非!请举例子说明C语言中的与、或、非是C语言的逻辑运算符。1、逻辑与在C语言中逻辑与用&&表示。举例:a&&b(其中a、b都代表一个条件)如果a和b都为真,则结果为真,如果a和.或非与非或与非都说下或:+与:*非:取反三个事件a,b,c或非就是先a+b,再取反与非就是先a*b,再取反&按位与|按位或~按位非^…

    2022年10月11日
    2
  • Java–Java版本和JDK版本「建议收藏」

    Java–Java版本和JDK版本「建议收藏」对于Java初学者,经常会听到同事,或看到网上Java版本和JDK版本不一的叫法,不明白这两者到底什么关系?其实博主当年初学Java时也有这样的困惑,今天我们就来好好探讨一下,如有不对之处,请加以指正,不喜勿喷,谢谢!Java版本叫法:Java6、Java8、Java11、Java13(当前最新版本Java17)等这一类“JavaX”的Java版本名称同时又会听到,看到JDK版本叫法:JDK1.6、JDK1.8等这种“J…

    2022年9月15日
    3
  • 树莓派能做什么?如何使用树莓派[通俗易懂]

    树莓派能做什么?如何使用树莓派[通俗易懂]我们知道树莓派是最常用的开发板,树莓派受欢迎的原因之一在于树莓派的功能非常全面,不论是做视频播放、音频播放等功能,树莓派都能派上用场。为增进大家对树莓派的认识,本文将带大家了解一下曾有人用树莓派做了什么。如果你对树莓派具有兴趣,不妨继续往下阅读哦。1、无线热点这大概是地球人拿来干的最多的一件——插上网线和USB无线网卡,配置之后就可以作为一个无线热点。2、机械假肢MITMediaLab的研究员把它作为机械假肢的控制器。3、简易自制笔记本把树莓派跟LCD液晶面板连上,再加上鼠标键盘

    2022年6月10日
    50
  • cuda 卸载_ubuntu怎么卸载cuda

    cuda 卸载_ubuntu怎么卸载cudahttps://blog.csdn.net/Teeyohuang/article/details/81052770cuda删除有效版本

    2025年9月20日
    4
  • mac java 配置环境变量配置_Mac 配置环境变量的方法

    mac java 配置环境变量配置_Mac 配置环境变量的方法一、单个环境变量的配置1、在英文输入法的状态下,按键盘“Ctrl+空格”组合键,调出Spotlight搜索(如果电脑右上角有放大镜的图标直接点击就可以)2、在Spotlight里输入终端(或者输入ter),点击enter即可打开终端3、以maven为例前提:1)先在命令行下敲:vi.profile(也可以是vi~/.profile这个是配置你自己当前用户的环境变量,别的用…

    2022年6月16日
    31
  • jieba库的安装教程_利用jieba库进行txt分词

    jieba库的安装教程_利用jieba库进行txt分词jieba库jieba库的安装jieba库的基本介绍jieba库的使用jieba库的安装(cmd命令行)pipinstalljiebajieba库的基本介绍(1)jieba库概述jieba库是优秀的中文分词第三方库。中文文本需要通过分词获得单个的词语;jieba是优秀的中文分词第三方库,需要额外安装;jieba库提供三种分词模式,最简单只需掌握一个函数;(2)jieba…

    2022年9月21日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号