el-upload上传图片,视频可获取视频时长。

对element-ui组件的upload组件再一次封装,简单记录。下面是效果图。

注意点:该组件现在仅支持单图和单个视频上传。

<template><div :style="myStyle"><divclass="uploads":style="{width: upWith + 'px',height: upHeight + 'px',borderRadius: upBradius + 'px',}"><div v-if="pathUrl" class="isblock"><div v-show="utype == 1"><el-imageref="preview":style="{width: upWith + 'px',height: upHeight + 'px',borderRadius: upBradius + 'px',}":preview-src-list="[pathUrl]":src="pathUrl"></el-image><div class="imgs_prews"><divclass="imgs_prew":style="{width: upWith + 'px',height: upHeight + 'px',borderRadius: upBradius + 'px',}"><i @click="ylimg()" class="el-icon-view"></i><span></span><i @click="deleteimg()" class="el-icon-delete"></i></div></div></div><div v-show="utype == 2" style="display: flex"><div style="position: relative"><video:style="{width: upWith + 'px',height: upHeight + 'px',borderRadius: upBradius + 'px',}":src="pathUrl"controlspreload="auto"playsinline="true"></video></div><div style="position: absolute; right: 0px"><el-button @click="deleteimg()" size="mini">重新上传</el-button></div></div></div><el-uploadv-elseclass="avatar-uploader":style="{width: upWith + 'px',height: upHeight + 'px',borderRadius: upBradius + 'px',lineHeight: upHeight + 'px',}":action="updatehttp":headers="headers":data="updataimg"accept=".jpg, .jpeg, .png, .gif, .bmp, .JPG, .JPEG, .PBG, .GIF, .BMP":show-file-list="false":on-success="handleAvatarSuccess":before-upload="beforeAvatarUpload":on-progress="topprogressicon"><div v-show="isopens"><i class="el-icon-loading"></i>上传中...</div><i v-show="!isopens" class="el-icon-plus avatar-uploader-icon-sf">{{uptext}}</i></el-upload></div></div>
</template><script>
import { getToken } from "@/utils/auth";
export default {props: {//改变文字uptext: {type: String,default: "上传图片",},upWith: {type: Number,default: 100,},upHeight: {type: Number,default: 100,},upBradius: {type: Number,default: 16,},upimgUrl: {type: String,},//1图片 2视频utype: {type: Number,default: 1,},},computed: {myStyle() {return {"--upWith": this.upWith + "px","--upHeight": this.upHeight + "px","--upBradius": this.upBradius + "px",};},},data() {return {updatehttp: '', //上传的接口headers: {Authorization: "Bearer " + getToken(), //自己的token},updataimg: {fileKey: "", //上传时携带参数},isopens: false, //上传加载图isok: false, //上传成功失败,dataFile: {path: "",videoTime: "",},pathUrl: "",};},watch: {upimgUrl: {handler(val) {if (val) {this.pathUrl = val;} else {this.pathUrl = "";}},deep: true,immediate: true,},},methods: {getTimes(file) {var content = file;//获取上传视频时长var url = URL.createObjectURL(content);var audioElement = new Audio(url);audioElement.addEventListener("loadedmetadata", (_event) => {this.dataFile.videoTime = parseInt(audioElement.duration);});},//上传成功handleAvatarSuccess(res, file) {if (this.isok) {this.dataFile.path = res.url;this.pathUrl = res.url;this.isopens = false;this.$emit("changeName", this.dataFile);}},//文件上传时topprogressicon(event, file, fileList) {if (this.isok) {this.isopens = true;}},//上传之前的操作beforeAvatarUpload(file) {if (this.utype == 1 && file.type.includes("image")) {const isLt2M = file.size / 1024 / 1024 < 2;if (!isLt2M) {this.$message.error("上传图片大小不能超过 2MB!");this.isok = false;} else {this.isok = true;}}else if (this.utype == 2 && file.type.includes("video")) {this.getTimes(file);const isLt2M = file.size / 1024 / 1024 < 500;if (!isLt2M) {this.$message.error("上传视频大小不能超过 500MB!");this.isok = false;} else {this.isok = true;}} else {this.$message.error("上传类型错误!");this.isok = false;}},//删除deleteimg() {this.pathUrl = "";this.$emit("changeName", "");},//预览ylimg() {this.$refs.preview.clickHandler();},},
};
</script><style scoped>
.uploads {position: relative;
}.avatar-uploader /deep/ .el-upload {width: var(--upWith);height: var(--upHeight);border-radius: var(--upBradius);
}.avatar-uploader-icon-sf {color: #999999;
}.avatar-uploader {border: 1px dashed #d9d9d9;width: 100%;text-align: center;
}.isblock {width: 100%;
}.isblock:hover .imgs_prews {display: block;
}.imgs_prews {display: none;
}.imgs_prew {position: absolute;top: 0;width: 100%;display: flex;justify-content: center;align-items: center;background: rgba(0, 0, 0, 0.6);color: #fff;
}/* 左右图标 */
.imgs_prew i {display: inline-block;font-size: 20px;cursor: pointer;
}.imgs_prew span {width: 2px;height: 18px;margin: 0px 20px;background-color: #fff;
}
</style>

组件注册两种方法。

1.全局注册直接

//上传图片
import UploadFile from '@/components/UploadImg'
Vue.component('UploadFile', UploadFile)

2.单页面使用

import UploadFile from "../../../components/UploadImg";
export default {name: "Post",components: { UploadFile },
}

页面如何使用

<template><div>//注意上传视频要修改utype为2<UploadFile:utype='1':up-with="140"  :upimgUrl="form.companyHead":up-height="160":up-bradius="10"uptext="请上传封面图"@changeName="changUrl"></UploadFile></div>
</template>methods: {changUrl(e){//e.videoTime 获取到视频的时长if (e) {this.form.companyVideo = e.path;} else {this.form.companyVideo = "";}}},

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/14020.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

代码随想录算法训练营第36期DAY36

贪心好难&#xff0c;希望能坚持到柳暗花明那天。 DAY36 1005K次取反后最大化的数组和 自己的方法&#xff0c;注意越界条件放在最前面就好&#xff1a; class Solution {public: int largestSumAfterKNegations(vector<int>& nums, int k) { //自己的…

vue中数据已经改变了,但是table里面内容没更新渲染!

解决方案&#xff1a; 给table或者el-table标签上添加一个动态key值&#xff0c;只要数据发生改变&#xff0c;key值变动一下即可 标签上&#xff1a; :key“timeStamp” 初始data&#xff1a;timeStamp:0, 更新数据&#xff1a;this.timeStamp 这样每次更新数据&#xff…

ChannelHandler和ChannelPipeline之一

目录 ChannelHandler Channel的生命周期 ChannelHandler的生命周期 ChannelInboundHandler接口 ChannelOutboundHandler接口 ChannelHandler适配器 资源管理 ChannelPipeline接口 修改ChannelPipeline 触发事件 ChannelHandler Channel的生命周期 Channel定义了一组和…

整理前期PS问题

前面问题汇总 一、字体显示 字体不显示主要有三个原因&#xff0c;其实在这里面我已经打了“国风”两字&#xff0c; 字体太大&#xff0c;输入框小 只需要把输入框拉大/改变字体 经过字体修改还没有&#xff0c;那就是字体颜色和背景一致 二、字体横竖排变换 将文字打好…

java中的Map集合

一、Map集合概述 1、Map集合以键值对的形式存储元素&#xff0c;是将键映射到值的对象 2、要求&#xff1a; &#xff08;1&#xff09;一个键最多映射一个值 &#xff08;2&#xff09;键不能重复&#xff0c;值可以重复 二、HashMap类 1、是Map接口的实现类 2、特点&a…

Webpack源码泄露到Vue快速入门

前言 1.webpack 源码泄露 1.1漏洞简介 1.2存在泄露的站点 1.3 如何判断是否存在漏洞 方法1: 方法2: 1.4.如何将js.map文件还原为项目文件 1. 4.1查看npm版本 1.4.2 安装reverse-sourcemap 1. 4.3.检查是否安装 ​1. 4.4 使用reverse-sourcemap进行js.map文件还原操作…

代码随想录-Day16

104. 二叉树的最大深度 方法一&#xff1a;深度优先搜索 class Solution {public int maxDepth(TreeNode root) {if (root null) {return 0;} else {int leftHeight maxDepth(root.left);int rightHeight maxDepth(root.right);return Math.max(leftHeight, rightHeight) …

深入解读HTTP状态码:分类、含义、应用场景与故障排查指南

HTTP状态码作为超文本传输协议(HTTP)响应的重要组成部分,为客户端与服务器之间的交互提供了清晰的状态反馈。本文将全面展开对HTTP状态码的深入解读,涵盖其分类、具体含义、典型应用场景以及在故障排查中的实用价值,旨在帮助开发者与运维人员更好地理解和应对各类HTTP响应…

Postman使用技巧

Postman是一款广泛使用的API开发和测试工具&#xff0c;专为简化Web服务API的开发、测试、文档编制和协作过程而设计。它支持各种HTTP请求方法&#xff0c;包括GET、POST、PUT、DELETE等&#xff0c;允许用户轻松地构建和发送请求&#xff0c;以及检查响应。 本文介绍几个提升效…

vscode 的 AI 协助插件 Tabnine / Codeium

4.1、Tabnine 描述&#xff1a;Tabnine 是一款基于深度学习技术的代码自动补全工具。该插件支持多种编程语言&#xff0c;包括 Python、JavaScript、TypeScript、Java 和 Go 等。它可以根据您输入的代码段和上下文信息&#xff0c;预测并推荐可能的代码补全选项&#xff0c;从而…

GitHub的原理及应用详解(三)

本系列文章简介&#xff1a; GitHub是一个基于Git版本控制系统的代码托管平台&#xff0c;为开发者提供了一个方便的协作和版本管理的工具。它广泛应用于软件开发项目中&#xff0c;包括但不限于代码托管、协作开发、版本控制、错误追踪、持续集成等方面。 GitHub的原理可以简单…

每周一算法:Prim算法求最小生成树

题目链接 [最短网络] 题目描述 Farmer John 被选为他们镇的镇长&#xff01;他其中一个竞选承诺就是在镇上建立起互联网&#xff0c;并连接到所有的农场。当然&#xff0c;他需要你的帮助。 FJ 已经给他的农场安排了一条高速的网络线路&#xff0c;他想把这条线路共享给其他…

第4章 网络层

4.1网络层的功能 1.异网互联:使用路由器连接数据链路层和物理层均不同的网络。【路由器连接的设备物理层&#xff0c;数据链路层和网络层可以不同】 2.转发:从一个端口输入保存后选择另一个端口转发【微观】 3.路由选择:选择合适的路由线路【宏观】 4.SDN的基本概念: 数据平…

【shell】脚本案例2

shell案例&#xff1a; 选择mysql版本 在上面的示例中&#xff0c;没有办法在选择了水果后退出&#xff0c;它会一直让我们选择。如果我们希望选择后就退出&#xff0c;则需要在脚本添加 break 打印九九乘法表 打印三角形&#xff08;10行10列&#xff09; 循环输出0~10之…

目前流行的前端框架有哪些?

目前流行的前端框架有很多&#xff0c;它们可以帮助开发者快速构建高质量的前端应用程序。本文将介绍一些目前比较受欢迎的前端框架&#xff0c;并分析它们的优缺点。 React React 是一个由 Facebook 开发的开源前端JavaScript库&#xff0c;用于构建用户界面&#xff0c;尤其…

Ollama本地运行 Mistral-7B-Instruct-v0.3

Ollama本地运行 Mistral-7B-Instruct-v0.3 0. 引言1. 运行 mistral:7b-instruct-v0.3-q8_02. 简单问个问题 0. 引言 Mixtral 5月23日发布了 Mistral-7B-Instruct-v0.3&#xff0c;支持 function calling&#xff0c;今天简单运行一下。 1. 运行 mistral:7b-instruct-v0.3-q8_…

头歌03-最长公共子序列

给定两个无序的序列 X{x_1,x_2,⋯,x_m } 和 Y{Y_1,Y_2,⋯,Y_n } ,求 X 和 Y 长度最长的公共子序列。 序列的子序列是指&#xff1a;从给定序列中随意地&#xff08;不一定连续&#xff09;去掉若干个字符&#xff08;可能一个也不去掉&#xff09;后所形成的字符序列。如果序列…

【AI如何帮你编写测试用例并输出表格格式】

1、工具&#xff1a;顺便使用一款生成式AI即可&#xff0c;此处用的是ChatGPT&#xff0c;Kimi这两个工具试验。 2、首先要拿到需求文档&#xff0c;根据需求文档向AI发出如下指令&#xff08;Prompt&#xff09; “请根据下面这段需求&#xff0c;编写测试用例&#xff1a; …

在CentOS上手动配置静态IP地址及多网卡路由策略

在管理服务器时&#xff0c;手动配置静态IP地址是一项基本而关键的任务&#xff0c;尤其是在涉及多网卡的复杂网络环境中。静态IP配置确保了服务器的稳定访问&#xff0c;有助于避免由于IP地址动态变化引起的潜在问题。本文将探讨如何在CentOS系统中手动设置静态IP地址&#xf…

python从0开始学习(十二)

目录 前言 1、字符串的常用操作 2、字符串的格式化 2.1 格式化字符串的详细格式&#xff08;针对format形式&#xff09; ​编辑 总结 前言 上一篇文章我们讲解了两道关于组合数据类型的题目&#xff0c;本篇文章我们将学习新的章节&#xff0c;学习字符串及正则表达式。 …