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


Posted in Javascript onDecember 18, 2018

前言

在实现图片上传时,可能需要用到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到页面上

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

Javascript 相关文章推荐
基于json的jquery地区联动效果代码
Jul 06 Javascript
jquery form表单获取内容以及绑定数据
Feb 24 Javascript
JavaScript学习笔记之取数组中最大值和最小值
Mar 23 Javascript
js小数计算小数点后显示多位小数的实现方法
May 30 Javascript
AngularJS中$apply方法和$watch方法用法总结
Dec 13 Javascript
解决jQuery ajax动态新增节点无法触发点击事件的问题
May 24 jQuery
js中apply()和call()的区别与用法实例分析
Aug 14 Javascript
微信小程序访问豆瓣电影api的实现方法
Mar 31 Javascript
vue.js中ref和$refs的使用及示例讲解
Aug 14 Javascript
Angular value与ngValue区别详解
Nov 27 Javascript
微信小程序request请求封装,验签代码实例
Dec 04 Javascript
原生JavaScript实现留言板
Jan 10 Javascript
微信小程序解除10个请求并发限制
Dec 18 #Javascript
vue项目中axios请求网络接口封装的示例代码
Dec 18 #Javascript
vue中引入第三方字体文件的方法示例
Dec 17 #Javascript
vue 表单验证按钮事件交由父组件触发的方法
Dec 17 #Javascript
Vue 报错TypeError: this.$set is not a function 的解决方法
Dec 17 #Javascript
vuex 解决报错this.$store.commit is not a function的方法
Dec 17 #Javascript
详解Vue This$Store总结
Dec 17 #Javascript
You might like
php下的权限算法的实现
2007/04/28 PHP
php中检查文件或目录是否存在的代码小结
2012/10/22 PHP
php session的应用详细介绍
2017/03/22 PHP
json2.js的初步学习与了解
2011/10/06 Javascript
给ListBox添加双击事件示例代码
2013/12/02 Javascript
jQuery获得内容和属性示例代码
2014/01/16 Javascript
回车直接实现点击某按钮的效果即触发单击事件
2014/02/27 Javascript
javascript的数组和常用函数详解
2014/05/09 Javascript
jQuery根据用户电脑是mac还是pc加载对应样式的方法
2015/06/26 Javascript
jquery实现可横向和竖向展开的动态下滑菜单效果
2015/08/24 Javascript
jQuery+jsp实现省市县三级联动效果(附源码)
2015/12/03 Javascript
Bootstrap编写一个在当前网页弹出可关闭的对话框 非弹窗
2016/06/30 Javascript
js仿小米官网图片轮播特效
2016/09/29 Javascript
Vue.js仿微信聊天窗口展示组件功能
2017/08/11 Javascript
利用JS制作万年历的方法
2017/08/16 Javascript
jQuery实现base64前台加密解密功能详解
2017/08/29 jQuery
vue-resource + json-server模拟数据的方法
2017/11/02 Javascript
ES6 系列之 WeakMap的使用示例
2018/08/06 Javascript
微信小程序--特定区域滚动到顶部时固定的方法
2019/04/28 Javascript
Vue项目vscode 安装eslint插件的方法(代码自动修复)
2020/04/15 Javascript
python解决字典中的值是列表问题的方法
2013/03/04 Python
Python字符串匹配算法KMP实例
2015/07/18 Python
python文件名和文件路径操作实例
2017/09/29 Python
对python当中不在本路径的py文件的引用详解
2018/12/15 Python
pymysql模块的使用(增删改查)详解
2019/09/09 Python
python基于TCP实现的文件下载器功能案例
2019/12/10 Python
纯CSS3实现手风琴风格菜单具体步骤
2013/05/06 HTML / CSS
在html5的Canvas上绘制椭圆的几种方法总结
2013/01/07 HTML / CSS
美国指甲油品牌:Deco Miami
2017/01/30 全球购物
屈臣氏菲律宾官网:Watsons菲律宾
2020/06/30 全球购物
杭州时比特电子有限公司SQL
2013/08/22 面试题
护理专业个人求职简历的自我评价
2013/10/13 职场文书
CAD制图设计师自荐信
2014/01/29 职场文书
抗洪救灾先进集体事迹材料
2014/05/26 职场文书
运动会演讲稿300字
2014/08/25 职场文书
关于springboot配置druid数据源不生效问题(踩坑记)
2021/09/25 Java/Android