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

国际电子商务网站建设企业推广哪个平台好

国际电子商务网站建设,企业推广哪个平台好,wordpress 代码转义,上海松江做网站#今天用el-upload感到很多不方便,遂决定自己封装一个。注:本文不提供表面的按钮样式和文件上传成功后的样式,需要自己创建。本文仅介绍逻辑函数# 1,准备几个表面用来指引上传的元素 2,创造统一的隐藏文件上传输入框&…

        #今天用el-upload感到很多不方便,遂决定自己封装一个。注:本文不提供表面的按钮样式和文件上传成功后的样式,需要自己创建。本文仅介绍逻辑函数#

1,准备几个表面用来指引上传的元素

2,创造统一的隐藏文件上传输入框,监听文件改变函数来监听文件的上传

    <input type="file"ref="fileInput" class="hidden" @change="handleFileUpload" :accept="currentFileType" 
/>

你放在哪里都行,反正要隐藏起来,用来调用点击事件

3,准备文件上传的Ref和上传成功的文件的数组,记得ref要绑定上面的输入框

  1. 创造ref绑定输入框,用于读取上传到文件相关信息
  2. 创建上传数组用于存放上传文件组合,有文件名字,文件类型,文件路径(图片和视频才有),文件大小
// 文件上传ref
const fileInput = ref<HTMLInputElement | null>(null)
// 上传的文件列表
const uploadedFiles = reactive<{name: string;type: 'file' | 'image' | 'video';url?: string;size: string;
}[]>([]);

4,点击表面的上传按钮时,调用隐藏的上传输入框的click事件

        事件要绑定在上面的隐藏输入框

const handleFile = () => {fileInput.value?.click()
}

5, 处理文件上传函数

  1.  如果文件数组为空则返回
  2. 检查文件大小,如果为video视频文件并且文件大小大于100MB同样返回
  3. 确定文件类型,同样使用startsWith函数
  4. 添加到文件上传列表中,包含名字,类型,创造的url(视频或图片才有),大小(格式化函数返回)
  5. 最后清除文件上传框
const handleFileUpload = (event: Event) => {const input = event.target as HTMLInputElement;if (!input.files || input.files.length === 0) {alert('您没有上传文件')return};Array.from(input.files).forEach(file => {// 检查视频文件大小if( file.type.startsWith('video/') && file.size > 100 * 1024 * 1024){alert(`视频文件${file.name}太大, 请限制在100MB以内`);return}// 确定文件类型let fileType: 'file' | 'image' | 'video' = 'file';if (file.type.startsWith('image/')) {fileType = 'image';} else if (file.type.startsWith('video/')) {fileType = 'video';}// 添加到上传列表uploadedFiles.push({name: file.name,type: fileType,url: fileType !== 'file' ? URL.createObjectURL(file) : undefined,size: formatFileSize(file.size)});alert(`已经添加:${file.name}`)})input.value = '';
}

6,格式化函数,用来计算文件大小,传入函数为文件的大小,单位B

  1. 定义大小四个单位
  2. 循环计算哪个大小单位,每次除以1024
  3. 最后返回得到的size是除完后的结果,toFixed保留一位小数
const formatFileSize = (bytes: number): string => {const units = ['B', 'KB', 'MB', 'GB']let size = byteslet unitIndex = 0while (size >= 1024 && unitIndex < units.length -1){size /= 1024unitIndex++;}return `${size.toFixed(1)} ${units[unitIndex]}`
}

7, 删除文件函数,需要绑定在删除元素上

比如绑定在文件删除按钮,点击时触发,传入文件数组的对应索引

  1. 如果对应文件存在URL路径,需要统一肢解路径,使用函数URL.revokeObjectURL(对应url字符串)
  2. splice根据索引删除对应元素
const removeFile = (index:number) =>{if (uploadedFiles[index].url)URL.revokeObjectURL(uploadedFiles[index].url)uploadedFiles.splice(index, 1)alert.warning('已删除文件')
}

8,清除函数,在组件销毁前调用

同第七条,在组件关闭前调用URL.revokeObjectURL函数解放url,防止永远无法复用

// 清理函数
const cleanupBlobUrls = () =>{uploadedFiles.forEach(file => {if (file.url)URL.revokeObjectURL(file.url)})
}
// 在组件销毁前调用
onBeforeUnmount(() => {cleanupBlobUrls()
})

9,最后在HTML中自由渲染函数即可 


  补充:

  • startWith函数:startsWith()用于确定此字符串是否以指定字符串的字符开头,并根据需要返回truefalse

  • 输入文件通过event.target.files去寻找,为上传文件组成的数组,有type,name,size等属性
  • URL.createObjectURL()接受文件(比如图片和视频),创建URL一个字符串,是一串指向传入文件的URL路径。
  • URL.revokeObjectURL()接受URL路径,释放URL和原本对应文件的链接

http://www.dtcms.com/wzjs/113954.html

相关文章:

  • 北京计算机培训机构网站seo策划方案案例分析
  • 专门做985招聘信息的网站网站优化公司认准乐云seo
  • 单位建设网站的意义友情链接如何交换
  • 做塑料哪个网站好无锡百姓网推广
  • 网站建设与设计论文企业培训内容有哪些
  • 建立网站主机产品线上营销方案
  • 石家庄做网站公司的电话数据分析师
  • 阿里巴巴网站怎样做的漂亮郑州网站开发顾问
  • 佛山 网站设计公司app推广文案
  • jsp动态网站开发实训报告迅雷bt磁力链 最好用的搜索引擎
  • 东阳市建设规划局网站百度客服电话人工服务热线电话
  • 随州有哪些网站建设的公司app拉新推广平台渠道
  • 电子商务网站建设调查报告网站优化塔山双喜
  • 广州番禺营销型网站建设找培训机构的网站
  • 天津做网站的公司排名搜索引擎优化的报告
  • 电商加盟网站建设微指数查询
  • 雄县阿里巴巴网站建设cps游戏推广平台
  • 息壤服务器网站打不开巩义网络推广
  • 家谱网站的首页怎么做网络促销
  • 请问做网站需要什么软件美工培训
  • 网站开发需求用什么软件搜索引擎分析论文
  • 龙岩建设局网站互联网营销培训平台
  • 网络专业毕业论文美国seo薪酬
  • 怎么做网站后期推广关键词查询网站的工具
  • 公众号开发网站做一个网站需要什么
  • 宝塔建设的网站火车头发布失败网站排名优化的技巧
  • 建设网站的流程seo是搜索引擎营销
  • 厦门 公司网站建设seo网站关键词优化
  • 电商网站建设解决方案兰州做网站的公司
  • 佛山外贸网站建设公司信息流广告怎么投放