在后台管理项目中,用户要求上传音频,并且自动获取音频时长。

第一步, import { Upload, Button, Icon } from 'antd';

第二步,在表单中使用 Upload 组件,上传音频:

<FormItem {...formItemLayout} label="英文音频信息">
  <Row gutter={8}>
    <Col span={12}>
      <Input type="text" placeholder="景点的英文音频信息" value={site.enAudio} disabled />
    </Col>
    <Col span={12}>
      <Upload
  action="/hserve/v2/file/upload/"    // 必选参数,上传的地址
  listType="picture"             // 上传列表的内建样式(text、picture、picture-card)
  showUploadList={false}                 // 是否显示 uploadList
  accept="audio/*"             // 接受上传的文件类型
  fileList={enAudioFileList}       // 已经上传的文件列表
  onChange={this.handleAudioChange}    // 上传文件改变时的状态
     >
     <Button>
    <Icon type="upload" /> 浏览
    </Button>
      </Upload>
    </Col>
  </Row>
</FormItem>
 
handleAudioChange = (type, { file, fileList }) => {
  if (file.status === 'done') {
    fileList[fileList.length - 1].url = file.response.path
    let lastFile = fileList[fileList.length - 1]
    this.setState({
      enAudioFileList: fileList,
      site: { ...this.state.site, enAudio: lastFile.url }
    })
  return
  }
  this.setState({ enAudioFileList: fileList })
}
 
第三步,使用 react-audio-player:
  import ReactAudioPlayer from 'react-audio-player'
   
  {
    site.cnAudio      //判断是否已有音频 url
    ? (
      <ReactAudioPlayer
        ref={(element) => { duration.cnDuration = element; }}
        src={site.cnAudio}
        onCanPlay={this.onCanPlay}
      />
    )
    : null
  }
 
  

  onCanPlay = () => {
    let duration = this.state.duration
    // duration.enDuration.audioEl.duration 返回的是一个带小数的数字,因此用 Math.round 做了下处
    let enDuration = duration.enDuration ? Math.round(duration.enDuration.audioEl.duration) : null
        enDuration = enDuration ? this.setDuration(enDuration) : null
    this.setState({
      site: {...this.state.site, enDuration: enDuration}
    })
  }
  
  // 将 duration 设为 00:00 的格式
  setDuration = (sec) => {
    let min = 0
 
    sec = sec <=10 ? '0' + sec : sec
    if (sec >= 60) {
      min = (sec / 60).toFixed()
      sec = sec % 60 >= 10 ? sec % 60 : '0' + sec % 60
    }
    min = min >= 10 ? min : '0' + min
    let time = min + ':' + sec
    return time
  }
 
音频时长为 this.state.site.enDuration。

 

 
 
 
 
 

ant design + react,自动获取上传音频的时长(react-audio-player)的更多相关文章

  1. js 获取上传视频的时长、大小、后缀名

    参考资料:获取时长 var fileName = $("#sectionfileUpload").val(); //C:\fakepath\3.jpeg var exts = fi ...

  2. 以springMVC为例获取上传视频文件时长

    毕设项目是一个在线学习系统,教师用户有上传视频的功能,在答辩之前赶了一个demo出来,好多功能都写死了,比如课程学习进度就是被我写死在前端的一个变量,最近导师要我把项目打包发给他,这才心慌慌赶紧把这些 ...

  3. Python3.6_x86通过FFpmeg获取视频或音频的时长和分辨率

    前言 前段时间公司在做流媒体服务,与许多厂家合作拿了许多视频过来,现在要对这些视频文件进行整理,通过特殊的编码排列,获取他们的时长以及分辨率,这里我遇到一个大坑,请往下面看. # -*- coding ...

  4. Shell32.ShellClass服务器操作系统无法获取 音频文件时长问题

    前言: 上传音频文件,自动写入此音频文件的时长,这里用 COM组件Microsoft Shell Controls And Automation来实现. 首先 1.引用:Microsoft Shell ...

  5. iOS开发进阶 - 使用shell脚本自动打包上传到fir.im上-b

    用fir.im测试已经好长时间了,感觉每次打包上传都很麻烦,想着是不是可以用脚本自动打包,在网上搜了一下确实有,下面总结一下如何使用脚本自动打包上传到fir.im,以及打包过程中遇到的问题和解决办法 ...

  6. Jmeter工具之上传图片,上传音频文件接口

    https://www.jianshu.com/p/f23f7fe20bf3 互联网时代的来临,不同手机上安装的APP,还是PC端的应用软件或多或多都会涉及到图片的上传,那么在Jmeter工具如何模拟 ...

  7. PHP使用APC获取上传文件进度

    今天发现使用PHP的APC也能获取上传文件的进度.这篇文章就说下如何做. 安装APC 首先安装APC的方法和其他PHP模块的方法没什么两样,网上能找出好多 phpinfo可以看到APC的默认配置有: ...

  8. php使用ffmpeg获取上传的视频的时长,码率等信息

    视频上传是程序员在很多时候需要用到的操作,然而上传完视频肯定要获得一些视频的详细信息,php本身是不支持信息获取的 ,所以采用ffmpeg第三方插件 首先你需要下载ffmpeg文件:官网地址:http ...

  9. ie下获取上传文件全路径

    ie下获取上传文件全路径,3.5之后的火狐是没法获取上传文件全路径的 /*获取上传文件路径*/ function getFilePath(obj) { var form = $(this).paren ...

随机推荐

  1. Codeforces Round #542 [Alex Lopashev Thanks-Round] (Div. 1)C. Morse Code

    题意:给你n个01字符,每次问你前缀的所有本质不同的子串,由摩斯密码组成的方案数和. 题解:离线处理,把字符建sam,通过topo序来dp计算每个节点表示的子串方案数的和.统计答案时,把n个字符挨个匹 ...

  2. Lua 语言基本语法

    第一个 Lua 程序 .交互式编程 Lua 提供了交互式编程模式.我们可以在命令行中输入程序并立即查看效果. Lua 交互式编程模式可以通过命令 lua -i 或 lua 来启用 .脚本式编程 我们可 ...

  3. RMAN 的优缺点及RMAN 备份及恢复步骤

    一. RMAN 备份的一些优点和OS命令备份方式相比,使用RMAN的优点 1  备份执行期间不需要人工干预,因此减少了误操作的机会:2  可以有效的将备份和恢复结合起来:3  支持除逻辑备份以外的所有 ...

  4. wireshark捕获/显示过滤器表达式书写规律说明

    一.说明 1.1 背景说明 对于大多数刚开始接触wireshark的使用者而言,经常是开始的时候时候看到wireshark能把所有数据包都拦截下来觉得强无敌,但是面对一大堆的数据包要问有什么用或者说想 ...

  5. python -- 字典 集合

    1.字典          定义:字典是以 key :value 的形式来保存数据,用{} 来表示,存储的是 key : value        查找效率比较高(注:字典存储数据时,用的是hash值 ...

  6. UVa LA 4254 - Processor 二分,贪心 难度: 1

    题目 https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_pr ...

  7. c、c++函数随机

    #inlcude<algorithm> next_permutation函数<全排列函数> #include<stdio.h> #include<algori ...

  8. C++实现 电子邮件客户端程序(简易版)

    #Windows操作系统下 用命令行工具实现发送邮件(编程前工作) 步骤: 1.telnet连接服务器(以用QQ邮箱向网易邮箱发送邮件为例,端口号25) 2.返回220 说明连接成功 3.ehlo发送 ...

  9. Linux设备驱动程序 第三版 读书笔记(一)

    Linux设备驱动程序 第三版 读书笔记(一) Bob Zhang 2017.08.25 编写基本的Hello World模块 #include <linux/init.h> #inclu ...

  10. 蓝牙协议分析(9)_BLE安全机制之LL Privacy

    1. 前言 在上一篇文章[1]中,我们介绍了BLE的白名单机制,这是一种通过地址进行简单的访问控制的安全机制.同时我们也提到了,这种安全机制只防君子,不防小人,试想这样一种场景: A设备表示只信任B. ...