# uni.chooseVideo(options)

拍摄视频或从手机相册中选视频,返回视频的临时文件路径。

# chooseVideo 兼容性

Web Android iOS
4.0 4.18 4.18

# 参数

名称 类型 必填 默认值 兼容性 描述
options ChooseVideoOptions - - -
名称 类型 必备 默认值 兼容性 描述
sourceType Array<string> | null - - album 从相册选视频,camera 使用相机拍摄,默认为:['album', 'camera']
success (callback: ChooseVideoSuccess) => void | null - - 接口调用成功,返回视频文件的临时文件路径,详见返回参数说明
fail (callback: IMediaError) => void | null - - 接口调用失败的回调函数
complete (callback: any) => void | null - - 接口调用结束的回调函数(调用成功、失败都会执行)
# ChooseVideoSuccess 的属性值
名称 类型 必备 默认值 兼容性 描述
tempFilePath string - - 选定视频的临时文件路径
duration number - - 选定视频的时间长度
size number - - 选定视频的数据量大小
height number - - 返回选定视频的长
width number - - 返回选定视频的宽
# IMediaError 的属性值
名称 类型 必备 默认值 兼容性 描述
errCode 1101001 | 1101002 | 1101003 | 1101004 | 1101005 | 1101006 | 1101007 | 1101008 | 1101009 | 1101010 - - 错误码
- 1101001 用户取消
- 1101002 urls至少包含一张图片地址
- 1101003 文件不存在
- 1101004 图片加载失败
- 1101005 未获取权限
- 1101006 图片或视频保存失败
- 1101007 图片裁剪失败
- 1101008 拍照或录像失败
- 1101009 图片压缩失败
- 1101010 其他错误
errSubject string - - 统一错误主题(模块)名称
data any | null - - 错误信息中包含的数据
cause Error | null - - 源错误信息,可以包含多个错误,详见SourceError
errMsg string - - -

# 参见

相关 Bug

# 示例

hello uni-app x

Template

Script

<template>
  <!-- #ifdef APP -->
  <scroll-view style="flex:1">
  <!-- #endif -->
    <page-head :title="title"></page-head>
    <view class="uni-padding-wrap">
      <video class="video" :src="src" :controls="true"></video>
      <view class="uni-title">
        <text class="uni-subtitle-text">视频信息</text>
      </view>
      <text>{{videoInfo}}</text>
      <view class="uni-btn-v">
        <button type="primary" @click="chooseVideo">选取视频</button>
      </view>
      <enum-data title="视频来源" :items="sourceTypeItemTypes" @change="onSourceTypeChange"></enum-data>
      <enum-data title="摄像头" :items="cameraItemTypes" @change="onCameraChange"></enum-data>
    </view>
    <input-data title="最长拍摄时间,单位秒" defaultValue="60" type="number" @confirm="onMaxDurationConfirm"></input-data>
    <!-- #ifdef APP -->
    <view class="uni-padding-wrap">
      <boolean-data title="是否压缩" :defaultValue="true" @change="onCompressedChange"></boolean-data>
    </view>
    <!-- #endif -->
  <!-- #ifdef APP -->
  </scroll-view>
  <!-- #endif -->
</template>



<style>
  .video {
    align-self: center;
    width: 300px;
    height: 225px;
  }
</style>

# 通用类型

# GeneralCallbackResult

名称 类型 必备 默认值 兼容性 描述
errMsg string - - 错误信息

# Tips

  • 本API会自动申请摄像头和相册权限,如需手动获取app是否拥有摄像头和相册权限,参考 uni.getAppAuthorizeSetting
  • app端拍摄和相册选择会在应用沙盒目录的cache目录产生临时文件,位置详见
  • app端如需主动删除临时文件,使用uni.getFileSystemManager