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

推广网站怎么建男生最喜欢的浏览器

推广网站怎么建,男生最喜欢的浏览器,宝塔面板怎么做自己的网站,国家市场监督管理总局局长什么级别Vue中实现大文件的切片下载 切片下载需要后端提供两个接口,第一个接口用来获取当前下载文件的总切片数,第二个接口用来获取具体某一个切片的内容。 界面展示 数据流展示 代码 接口 // 切片下载-获取文件的总切片数 export function getChunkDownload…

Vue中实现大文件的切片下载

切片下载需要后端提供两个接口,第一个接口用来获取当前下载文件的总切片数,第二个接口用来获取具体某一个切片的内容。

界面展示

在这里插入图片描述

数据流展示

在这里插入图片描述

代码

接口

// 切片下载-获取文件的总切片数
export function getChunkDownloadMetaInfo(queryParams) {return request({url: `/resource/chunkDownloadMetaInfoByUrl`,method: 'get',params: queryParams})
}// 切片下载-获取当前切片的文件内容
export function getChunkDownload(queryParams) {return request({url: `/resource/chunkDownloadByUrl`,method: 'get',headers: {'Content-Type': 'application/json; application/octet-stream'},responseType: 'blob', //响应数据格式配置params: queryParams})
}

下载

// 下载
const downloadItem = async item => {const fileName = item.fileNameconst fileUrl = item.fileUrlif (item.isDownloading) {ElMessage({type: 'error',message: `${fileName}正在下载中请稍等`})return}item.progress = 0 // 下载进度item.isDownloading = true // 是否正在下载item.isAborted = false // 是否中止下载try {// 获取文件信息const fileInfo = await getFileInfo(fileUrl)const totalChunks = fileInfo.totalChunkNum// 并发下载所有切片const downloadedChunks = await downloadWithConcurrency(fileUrl, fileName, totalChunks, item)// 合并并下载文件const mergedBlob = mergeBlobs(downloadedChunks)triggerDownload(mergedBlob, fileName)} catch (error) {console.error('下载失败:', error)ElMessage({type: 'error',message: `${fileName}文件下载失败`})} finally {item.isDownloading = false}
}
// 获取文件信息
const getFileInfo = async fileUrl => {try {const response = await getChunkDownloadMetaInfo({ url: fileUrl })return response.data} catch (error) {throw new Error(`获取文件信息失败: ${error.message}`)}
}
// 下载单个切片
const downloadChunk = async (fileUrl, fileName, chunkIndex) => {try {const response = await getChunkDownload({url: fileUrl,chunkNumber: chunkIndex})return response} catch (error) {throw new Error(`下载切片失败: ${error.message}`)}
}
// 合并 Blob
const mergeBlobs = blobs => {return new Blob(blobs)
}
// 触发文件下载
const triggerDownload = (blob, fileName) => {const url = URL.createObjectURL(blob)const a = document.createElement('a')a.href = urla.download = fileNamea.click()URL.revokeObjectURL(url)
}
// 并发下载
const downloadWithConcurrency = async (fileUrl, fileName, totalChunks, item) => {const downloadedChunks = new Array(totalChunks).fill(null)let completedChunks = 0const downloadNextChunk = async chunkIndex => {if (item.isAborted) return // 如果已中止,直接返回try {const chunk = await downloadChunk(fileUrl, fileName, chunkIndex)console.log(chunk, '123123123123123123')downloadedChunks[chunkIndex] = chunk// 更新下载进度completedChunks++item.progress = Math.round((completedChunks / totalChunks) * 100)} catch (error) {item.isAborted = true // 中止下载throw error}}// 启动并发下载const workers = []for (let i = 0; i < totalChunks; i++) {if (item.isAborted) break // 如果已中止,停止启动新任务if (workers.length >= maxConcurrency) {// 等待一个任务完成后再启动新任务await Promise.race(workers)}const worker = downloadNextChunk(i).finally(() => {workers.splice(workers.indexOf(worker), 1)})workers.push(worker)}await Promise.all(workers) // 等待所有任务完成return downloadedChunks
}
http://www.dtcms.com/wzjs/480636.html

相关文章:

  • 网件路由器管理地址石家庄seo优化
  • 怎样用织梦做音乐网站关键词优化课程
  • 无锡市建设安全监督网站山西搜索引擎优化
  • 珠海企业网站建设公百度招商加盟推广
  • 中国建设招标网是私人网站吗认识网络营销
  • 做的课件能做教育部网站查询码站长工具免费
  • 专业营销推广公司网络优化培训
  • 国务院关于新时期政府网站建设百度 搜索热度
  • 建设企业网站的黑帽seo之搜索引擎
  • 百度提交网站多久收录携程: 2023年旅行搜索上涨超900%
  • 西宁微信网站建设需要多少钱济南seo整站优化价格
  • 个人网站备案简介怎么写搜索引擎优化技巧
  • wordpress 插件 原理邯郸网站建设优化
  • 遵义建设厅官方网站 元丰怎么开发网站
  • 百度seo网站优化链接平台
  • 如何做好营销推广河南网站优化
  • 中国住房与建设委员会网站今天大事件新闻
  • 影视网站怎么做网站推广软件下载安装免费
  • 免费模板建站网站网络营销课程个人总结
  • 福州网站建设公司学技术的培训学校
  • 建立官方网站如何制作网页教程
  • 网站标题改动网站设计方案
  • 罗湖做网站的公司牡丹江seo
  • 公司网站运营维护单位软文广告100字
  • 赌钱网站怎么做的软件测试培训班多少钱
  • 商标logo设计软件 免费信息流优化师怎么入行
  • 西安网站建设g强强seo博客
  • 潮州网站建设搜索关键词排名提升
  • 长沙企业如何建网站西安做网站公司
  • 南京建设公司网站凡科建站app