欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

antd组件Upload实现自己上传的实现示例

程序员文章站 2022-06-22 15:41:10
前言 在实现图片上传时,可能需要用到upload,但是它默认的上传方式是加入图片后直接上传,如果要实现最后再一次性上传,需要自定义内容。 //添加按钮的样式...

前言

在实现图片上传时,可能需要用到upload,但是它默认的上传方式是加入图片后直接上传,如果要实现最后再一次性上传,需要自定义内容。

antd组件Upload实现自己上传的实现示例antd组件Upload实现自己上传的实现示例

//添加按钮的样式
const uploadbutton = (
  <div>
  <icon type="plus" />
  <div classname="ant-upload-text">upload</div>
  </div>
 );


<upload
    //样式
    classname={styles['override-ant-btn']}
    //陈列样式,现在是卡片式
    listtype="picture-card"
    //再图片上传到页面后执行的函数,自定义让他不执行
    beforeupload={() => false}
    //数据,即图片,是一个数组
    filelist={filelist}
    //当点击查看时调用(上图的那个眼睛)
    onpreview={this.handlepreview}
    //数据改变时调用
    onchange={this.handlechange}
   >
    //当不少于一张图时,不显示怎加图片的按钮。
    {filelist.length >= 1 ? null : uploadbutton}
   </upload>

还有一个移除时调用的函数onremove(),即点击上图的垃圾桶,这里没有定义。

 handlepreview = (file) => {
 this.setstate({
  previewimage: file.url || file.thumburl,
  visible: true,
 });
 };


  <modal visible={visible} footer={null} oncancel={this.handlecancel}>
    <img alt="加载" style={{ width: '100%',height: '100%' }} src={previewimage} />
  </modal>

利用modal显示图片。

handlechange = ({ filelist }) => {
 this.setstate({ filelist });
};

数据改变时直接重设filelist数组的值(我这里只有一张图可以这么做)。

最后是filelist的一些基本设置:

filelist: [{
   uid: 'id',
   name: '标题',
   //目前的状态
   status: 'done',
   //图片的url或者base64
   url: '',
   type: 'image/jpeg',
  }],

ps:基于antd的上传文件进度条

核心代码

//通过前端原生xmlhttprequest动态获取上传文件进度
dotransferfile = (file) => {
 let myself = this;
 let formdata = new formdata();
 let url = "http://xxx:444/upload_file.php";
 let file = document.getelementbyid("choosefile").files[0];
 console.log(file)
 
 formdata.append("file",file);
 // console.log(modal);
 // console.log(formdata);
 // return false;
 /* eslint-disable */
 $.ajax({ 
  url : url, 
  type : 'post',
  enctype: 'multipart/form-data',
  data : formdata, 
  // 告诉jquery不要去处理发送的数据
  processdata : false, 
  // 告诉jquery不要去设置content-type请求头
  contenttype : false,
  timeout : 60000,//设置超时时间
  beforesend:function(){
   console.log("现在开始上传文件!");
 notification['info']({
 message: '提示',
 description: '现在开始上传文件!',
 });
  },
  xhr: function(){
 let myxhr = $.ajaxsettings.xhr();
 // console.log(myxhr)
 if(myxhr.upload){
 myxhr.upload.addeventlistener('progress',function(e) {
  if (e.lengthcomputable) {
  let percent = math.floor((e.loaded/e.total)*100);
  // console.log(e.loaded)
  // console.log(e.total)
  console.log(percent)
  let upload = myself.state.upload;
  upload.progress.loaded = e.loaded;
  upload.progress.total = e.total;
  upload.progress.percentage = percent;
  myself.state.upload = upload;
 
  // console.log(info);
   myself.setstate({
    upload: upload
   });
  }
 },false);
 
 myxhr.upload.addeventlistener('load',function(e) {
  console.log('fish')
 },false);
 
 }
 return myxhr;
  },
  success : function(res) {
   console.log(res)
 
  }, 
  error : function(res) { 
 
  } 
 });
};

在antd框架下,调用的progress组件动态展示的上传文件进度,效果图如下,待全部上传成功后,由接口返回上传文件的大小,路径等信息,render到页面上

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。