JavaScript中URL.createObjectURL和Blob实现保存文件

 更新时间:2025年07月17日 10:23:43   作者:Mr.怪兽  
本文介绍了利用JavaScript中的Blob对象和URL.createObjectURL方法在浏览器端创建文件并实现下载功能,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧

1.实现原理

生成blob对象,再使用URL.createObjectURL() 创建一个非跨域的数据源,然后在页面写入a标签支持下载。

Blob表示二进制类型的大对象,通常是影像、声音或多媒体文件0。

通过URL.createObjectURL(blobVal) 获取要保存的文件的一个URL,这个URLhash,保存在内存中。

通过URL.revokeObjectURL()来释放这个object URL,通知浏览器不再继续引用这个文件

跨域文件下载处理方法:

  1. download 就是跨域的问题,如果加载了非同源的内容,该属性会失效不能下载,只会在浏览器中导航到该内容。
  2. 在服务器设置 Content-Disposition 使用HTTP响应头 Content-Disposition 进行处理。
  3. 先下载源数据文件,生成blob对象,再使用URL.createObjectURL()创建一个非跨域的数据源,然后在页面写入a标签支持下载。

2.代码实现

<template>
  <div>URL.createObjectURL、Blob 实现保存文件</div>
  <button ref="btnRef">下载</button>
</template>
​
<script setup lang='ts'>
import {onMounted, ref} from 'vue'
​
let btnRef = ref()
let fileUrl = ''
​
onMounted(()=>{
    btnRef.value.addEventListener('click',()=>{
    let str = '这里时要保存的文字内容'
    const blobVal = new Blob([str],{type:'text/plain'})
    console.log(blobVal);
​
    // 创建了一个blob 的地址
    fileUrl = URL.createObjectURL(blobVal)
    console.log(fileUrl);
        
​
    let aDom = document.createElement('a')
    // 第一种写法
    // aDom.setAttribute('href',fileUrl)
    // aDom.setAttribute('download','导出文件.txt')
    // 第二种写法
    aDom.href = fileUrl
    aDom.download = '导出文件.txt'
    aDom.click()
    URL.revokeObjectURL(fileUrl)
    
​
    })
})
​
</script>
<style scoped lang='less'>
</style>

3.结果显示

到此这篇关于JavaScript中URL.createObjectURL和Blob实现保存文件的文章就介绍到这了,更多相关URL.createObjectURL和Blob保存文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • el-form实现表单和图片手动上传和校验功能

    el-form实现表单和图片手动上传和校验功能

    在写项目时,难免遇到需要上传表单,图片等文件,且表单内容需进行验证及必填项提示,图片需要和信息一起传递且图片载入后需可预览,这篇文章给大家介绍el-form实现表单和图片手动上传和校验功能,感兴趣的朋友一起看看吧
    2024-01-01
  • javascipt匹配单行和多行注释的正则表达式

    javascipt匹配单行和多行注释的正则表达式

    用JSON.parse 来转换成json对象,由于有注释的存在则无法正确转换甚至报错。匹配字符串中的所有注释,包括单行和多行注释
    2013-11-11
  • JS获取input file绝对路径的方法(推荐)

    JS获取input file绝对路径的方法(推荐)

    下面小编就为大家带来一篇JS获取input file绝对路径的方法(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • 用于deeplink的js方法(判断手机是否安装app)

    用于deeplink的js方法(判断手机是否安装app)

    这篇文章主要介绍了用于deeplink的js方法(判断手机是否安装app),需要的朋友可以参考下
    2014-04-04
  • Bootstrap select实现下拉框多选效果

    Bootstrap select实现下拉框多选效果

    这篇文章主要为大家详细介绍了Bootstrap select实现下拉框多选效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • a标签置灰不可点击的实现方法

    a标签置灰不可点击的实现方法

    下面小编就为大家带来一篇a标签置灰不可点击的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-02-02
  • JavaScript文件上传的常见问题整理

    JavaScript文件上传的常见问题整理

    这篇文章整理了JavaScript文件上传的常见问题,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • raphael.js绘制中国地图 地图绘制方法

    raphael.js绘制中国地图 地图绘制方法

    在本文中给大家分享如何使用raphael.js来完成地图交互,raphael.js是一个很小的javascript库,它可以在网页中实现绘制各种矢量图、各类图表、以及图像裁剪、旋转、运动动画等等功能,需要的朋友可以参考下
    2014-02-02
  • JS实现用户管理系统

    JS实现用户管理系统

    这篇文章主要为大家详细介绍了JS实现用户管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • JS实现电商商品展示放大镜特效

    JS实现电商商品展示放大镜特效

    这篇文章主要为大家详细介绍了JS实现电商商品展示放大镜特效,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-01-01

最新评论