当前位置: 首页 > news >正文

人大常委会网站建设nba实力榜最新排名

人大常委会网站建设,nba实力榜最新排名,上海企业信息,网站推广专家十年乐云seo背景 需求场景: 后台管理系统: (1)配置中支持上传视频、上传成功后封面缩略图展示,点击后自动播放视频; (2)配置中支持上传多个文件; 前台系统: &#…

背景

需求场景:

后台管理系统:

(1)配置中支持上传视频、上传成功后封面缩略图展示,点击后自动播放视频;

(2)配置中支持上传多个文件;

前台系统:

(1)展示视频列表并点击播放;

(2)展示文件列表并点击下载;

说明

看需求似乎很简单,再加上本身antd-design已经封装好的Upload组件,功能强大且丰富;但是具体需求场景中还是有不少交互细节,也花了一些时间调试,为以后碰到类似场景更快速高效实现,记录和分享出来

上传视频且展示缩略图

  1. 上传视频处理:

获取视频数据,并执行上传方法;一般二进制处理,可以支持各类文件格式,本质视频也是文件的一种格式;这一步其实很简单,参考Upload组件的相关实例即可,

<Uploadmultiple={true}fileList={videoList}listType="picture"beforeUpload={(file) => {const formData = new FormData();formData.append('file', file, file.name);request(`/upload/binary`, {method: 'post',body: formData,}).then((res: any) => {setVideoList([...videoList,{name: file.name,url: res.data,thumbUrl: `${res?.data}`,},]);});}}className={styles['upload-list-inline']}
><Button icon={<UploadOutlined />}>上传视频</Button><span className={styles['upload-tip']}>仅支持 rm,rmvb, wmv,avi, mpg, mpeg,mp4等格式,单个视频最大不得超过500M。</span>
</Upload>

上述代码listType字段设为“picture”,实例效果如下:

  1. 前台展示列表,demo代码如下:
<div className="introduction"><div className="app-message-title">视频教程</div>{videoList.map((item: FileProps, index: number) => {return (<div key={index} onClick={() => handleVideo(item)}><imgclassName="video-icon"src={require("icon.png")}/>{/* <a href={item.url} className="file-name">{item.name}</a> */}<span className="file-name">{item.name}</span></div>);})}
</div>

(1)实现代码如下:被注释掉的代码:交互效果,点击直接新开页

上传的不同尺寸,播放时按原视频的宽高:

缺点:新开页打开,不利于用户操作

(2)点击后弹窗展示,实现思路是使用antd的Modal组件,承载视频播放组件:

<Modalwidth={curVideo.width}bodyStyle={{ height: curVideo.height }}wrapClassName="video-modal"footer={null}visible={visible}onCancel={() => {setCurVideo(undefined);setVisble(false);}}
><video src={curVideo.url} controls preload="auto" autoPlay={true} />
</Modal>

  1. 这里其实有一个问题,因为上传时不显示视频上传的像素,那么弹窗的宽高需要与视频的框高相同,所以上传的时候需要拿到视频的宽高:如何拿到视频宽高?
<Uploadmultiple={true}fileList={videoList}listType="picture"beforeUpload={(file) => {console.log('fiel = ', file);const videoUrl = URL.createObjectURL(file);const videoObj = document.createElement("video");videoObj.onloadedmetadata = function () {URL.revokeObjectURL(videoUrl);console.log("JJJJJ", videoObj.videoWidth, videoObj.videoHeight);  // 拿到视频的宽高// 执行上传的方法,获取外网路径,上传进度等const formData = new FormData();formData.append('file', file, file.name);request(`/upload/binary`, {method: 'post',body: formData,}).then((res: any) => {setVideoList([...videoList,{name: file.name,url: res.data,thumbUrl: `${res?.data}`,  // 缩略图图片地址width: videoObj.videoWidth,  height: videoObj.videoHeight,},]);});};videoObj.src = videoUrl;videoObj.load();}}className={styles['upload-list-inline']}
><Button icon={<UploadOutlined />}>上传视频</Button><span className={styles['upload-tip']}>仅支持 rm,rmvb, wmv,avi, mpg, mpeg,mp4等格式,单个视频最大不得超过500M。</span>
</Upload>

这样就解决了,Modal弹窗承载视频播放,Modal弹窗的宽高与视频的宽高一致;

http://www.hengruixuexiao.com/news/10735.html

相关文章:

  • 手机做任务佣金的网站培训机构好还是学校好
  • 个人网站建设素材武汉seo霸屏
  • 好的文化网站模板怎么制作百度网页
  • nginx rewrite wordpress重庆seo整站优化报价
  • 中建建设银行网站seo优化公司排名
  • 德州建设局网站点金推广优化公司
  • 馆陶专业做网站花都网络推广seo公司
  • 做枪版视频网站犯法吗企业培训系统
  • 政府网站整改 对做网站关键字销售平台有哪些
  • 网站内容的编辑和更新怎么做的东莞市民最新疫情
  • 网站怎么做优化推广信息发布网站有哪些
  • 女孩和狗做网站app推广怎么做
  • 网站开发企业需要什么资质百度搜索热词排行榜
  • 上海建设集团网站seo优化广告
  • 成都网站建设有名的企业网络搭建方案
  • 专业做化学招聘的网站有哪些2023年免费进入b站
  • 网站建设甲方原因造成停工app下载注册量推广平台
  • 如何做网站百科竞价排名服务
  • 公司网站建设需求书今日热搜榜排名
  • 有没有帮人做CAD的网站千峰培训出来好就业吗
  • 北京企业官网网站建设哪家好全球十大搜索引擎排名
  • 店铺推广是如何收费的seo排名第一的企业
  • 基于php网站开发小姐关键词代发排名
  • 买一个成品网站多少钱上海网站设计公司
  • 免费b2b网站推广嘿嘿哪个搜索引擎能搜敏感内容
  • 网站建设基本知识百度指数查询官网
  • 3d网站建设站长工具seo综合查询广告
  • seo案例网站建设哪家好网站权重查询工具
  • 怎么做网站搜索关键词磁力
  • 知名网站制作公司2022智慧树互联网与营销创新