iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Blob对象如何实现文件上传下载功能
  • 904
分享到

Blob对象如何实现文件上传下载功能

2023-07-04 22:07:53 904人浏览 独家记忆
摘要

本篇内容介绍了“Blob对象如何实现文件上传下载功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!什么是Blod?Blob 对象表示一个不可

本篇内容介绍了“Blob对象如何实现文件上传下载功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

    什么是Blod?

    Blob 对象表示一个不可变、原始数据的类文件对象,它的数据类型可以按文本或二进制的格式进行读取

    Blob的属性与方法

    • size返回一个File对象所指代的文件的大小,单位为字节

    • typeBlob 对象的 type 属性给出文件的 MIME 类型。如果类型无法确定,则返回空字符串

    • arrayBuffer()arrayBuffer() 方法返回一个 Promise 对象,包含 blob 中的数据,并在 ArrayBuffer 中以二进制数据的形式呈现。

    • slice()Blob.slice() 方法用于创建一个包含源 Blob的指定字节范围内的数据的新 Blob 对象可以用于大文件上传;

    • stream()Blob接口的stream() 方法返回一个ReadableStream对象,读取它将返回包含在Blob中的数据。

    • text()text() 方法返回一个 Promise 对象,包含 blob 中的内容,使用 UTF-8 格式编码

    • File 文件(File)接口提供有关文件的信息,并允许网页中的 javascript 访问其内容

    File 对象是特殊类型的 Blob,且可以用在任意的 Blob 类型的 context 中。比如说, FileReader, URL.createObjectURL(), createImageBitmap() (en-US), 及 XMLHttpRequest.send() 都能处理 Blob 和 File

    • FileList 一个 FileList 对象通常来自于一个 html <input> 元素的 files 属性,你可以通过这个对象访问到用户所选择的文件

    • FileReader FileReader 对象允许WEB应用程序异步读取存储在用户计算机上的文件(或原始数据缓冲区)的内容,使用 File 或 Blob 对象指定要读取的文件或数据

    • FileReaderSyncFileReaderSync接口允许以同步的方式读取File或Blob对象中的内容

    使用

    var domstr = ['<a id="a"><b id="b">hey!</b></a>']; // 一个包含DOMString的数组var Blob = new Blob(domstr, {type : 'text/html'}); // 得到 blob

    domstr 是一个由ArrayBuffer, ArrayBufferView, Blob, DOMString 等对象构成的 Array ,或者其他类似对象的混合体,它将会被放进 Blob。DOMStrings会被编码为UTF-8type,默认值为 "",它代表了将会被放入到blob中的数组内容的MIME类型。到这里相信大家都对Blod应该都了解了,开始实践案例:

    Blod下载指定类型文件

    指定下载一个html页面,如果想下载其他文件请在type下指定即可

    let str = `<a id="a"><b id="b">hey!</b></a>`;function downloadHtml(str){     let blob = new Blob({str},{        type:'text/html'     })     let url = URL.createObjectURL(blob);     let Doma = document.createElement('a');     Doma.setAttribute('download','index.html');     Doma.setAttribute('href',url);     Doma.click();  // 触发事件     Doma.remove(); // 移除本身}downloadHtml(str)

    Blod对象中type值根据自己下载的文件MIME类型进行定义,上面已经介绍过,然后创建a标签,当a标签上存在download属性的时候,那href的地址就会变为下载地址,再使用createObjectURL可以将blob对象转化为url,触发a标签实现下载功能

    上传

    • createObjectURL同步方式读取

    <input type="file" id="input" >// jslet input = document.getElementsById('input');input.onchange = (e)=>{     const files = e.target.files[0];     console.log(files)     let url = URL.createObjectURL(files);     let img = new Image();     img.src = url;     body.appendChild(img)}

    看一下打印的files对象与url地址

    Blob对象如何实现文件上传下载功能

    • 我们会发现上传的文件的原型链上存在Blob,说明继承Blob,url的地址是存在映射的,当我们上传了文件后会被存储起来,而他后面的UUid对应的就是我们上传图片的内存地址,这样我们再页面上就可以看到效果了。

    Blob对象如何实现文件上传下载功能

    FileReader对象的异步方式读取

    首先先介绍一下 FileReader对象

    FileReader 对象允许Web应用程序异步读取存储在用户计算机上的文件(或原始数据缓冲区)的内容,使用 File 或 Blob 对象指定要读取的文件或数据。官方提示FileReader仅用于以安全的方式从用户(远程)系统读取文件内容 它不能用于从文件系统中按路径名简单地读取文件;

    FileReader常用属性与方法

    • FileReader.readyState 状态:0还没有加载任何数据,1数据正在被加载.,2已完成全部的读取请求.

    • FileReader.result 文件的内容。该属性仅在读取操作完成后才有效,数据的格式取决于使用哪个方法来启动读取操作。

    • FileReader.onabort 该事件在读取操作被中断时触发

    • FileReader.onerror 该事件在读取操作发生错误时触发。

    • FileReader.onload 该事件在读取操作完成时触发。

    • FileReader.onloadstart 该事件在读取操作开始时触发。

    • FileReader.onloadend 该事件在读取操作结束时(要么成功,要么失败)触发。

    • FileReader.onprogress 该事件在读取Blob时触发。;

    还有一些方法就不每个介绍了,想深入了解的点击,我们先看下面的例子:

    // html<input type="file" id="input" >// jslet input = document.getElementById('input');input.onchange = (e)=>{     const files = e.target.files[0];     console.log(files)     let reader = new FileReader();     let img = new Image();     reader.readAsDataURL(files);     reader.onload = function(){        //读取完毕后输出结果        img.src = this.result;        console.log(this.result);     }     document.body.appendChild(img);}
    • 当我们触发input的onchange事件之后直接获取files并读取文件,在创建Img对象,将获取的内容赋给img.src再将img追加在body,就可以达到浏览效果了。

    • 生成的图片地址是base64的

    Blob对象如何实现文件上传下载功能

    • 效果图

    Blob对象如何实现文件上传下载功能

    “Blob对象如何实现文件上传下载功能”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

    --结束END--

    本文标题: Blob对象如何实现文件上传下载功能

    本文链接: https://www.lsjlt.com/news/347956.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • C++ 生态系统中流行库和框架的贡献指南
      作为 c++++ 开发人员,通过遵循以下步骤即可为流行库和框架做出贡献:选择一个项目并熟悉其代码库。在 issue 跟踪器中寻找适合初学者的问题。创建一个新分支,实现修复并添加测试。提交...
      99+
      2024-05-15
      框架 c++ 流行库 git
    • C++ 生态系统中流行库和框架的社区支持情况
      c++++生态系统中流行库和框架的社区支持情况:boost:活跃的社区提供广泛的文档、教程和讨论区,确保持续的维护和更新。qt:庞大的社区提供丰富的文档、示例和论坛,积极参与开发和维护。...
      99+
      2024-05-15
      生态系统 社区支持 c++ overflow 标准库
    • c++中if elseif使用规则
      c++ 中 if-else if 语句的使用规则为:语法:if (条件1) { // 执行代码块 1} else if (条件 2) { // 执行代码块 2}// ...else ...
      99+
      2024-05-15
      c++
    • c++中的继承怎么写
      继承是一种允许类从现有类派生并访问其成员的强大机制。在 c++ 中,继承类型包括:单继承:一个子类从一个基类继承。多继承:一个子类从多个基类继承。层次继承:多个子类从同一个基类继承。多层...
      99+
      2024-05-15
      c++
    • c++中如何使用类和对象掌握目标
      在 c++ 中创建类和对象:使用 class 关键字定义类,包含数据成员和方法。使用对象名称和类名称创建对象。访问权限包括:公有、受保护和私有。数据成员是类的变量,每个对象拥有自己的副本...
      99+
      2024-05-15
      c++
    • c++中优先级是什么意思
      c++ 中的优先级规则:优先级高的操作符先执行,相同优先级的从左到右执行,括号可改变执行顺序。操作符优先级表包含从最高到最低的优先级列表,其中赋值运算符具有最低优先级。通过了解优先级,可...
      99+
      2024-05-15
      c++
    • c++中a+是什么意思
      c++ 中的 a+ 运算符表示自增运算符,用于将变量递增 1 并将结果存储在同一变量中。语法为 a++,用法包括循环和计数器。它可与后置递增运算符 ++a 交换使用,后者在表达式求值后递...
      99+
      2024-05-15
      c++
    • c++中a.b什么意思
      c++kquote>“a.b”表示对象“a”的成员“b”,用于访问对象成员,可用“对象名.成员名”的语法。它还可以用于访问嵌套成员,如“对象名.嵌套成员名.成员名”的语法。 c++...
      99+
      2024-05-15
      c++
    • C++ 并发编程库的优缺点
      c++++ 提供了多种并发编程库,满足不同场景下的需求。线程库 (std::thread) 易于使用但开销大;异步库 (std::async) 可异步执行任务,但 api 复杂;协程库 ...
      99+
      2024-05-15
      c++ 并发编程
    • 如何在 Golang 中备份数据库?
      在 golang 中备份数据库对于保护数据至关重要。可以使用标准库中的 database/sql 包,或第三方包如 github.com/go-sql-driver/mysql。具体步骤...
      99+
      2024-05-15
      golang 数据库备份 mysql git 标准库
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作