广告
返回顶部
首页 > 资讯 > 精选 >html5中怎么将图片的绝对路径转换成文件对象
  • 216
分享到

html5中怎么将图片的绝对路径转换成文件对象

2023-06-09 21:06:30 216人浏览 八月长安
摘要

这篇文章将为大家详细讲解有关HTML5中怎么将图片的绝对路径转换成文件对象,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体如下:我们先来理解基本知识点:1. 理解HTML5中的FileList对象与fi

这篇文章将为大家详细讲解有关HTML5中怎么将图片的绝对路径转换成文件对象,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

具体如下:

我们先来理解基本知识点:

1. 理解HTML5中的FileList对象与file对象。

html5中,FileList对象表示用户选择的文件列表。通过添加multipe属性,file控件内允许一次选择多个文件。控件内的每一个用户选择的文件都是一个file对象,而FileList对象则是file对象的列表。代表用户选择的所有文件。我们先来看一个简单的demo,看下file文件对象有哪些属性。如下代码:

<!DOCTYPE html><html>  <head>    <title>filesystem:URL</title>  </head>  <body>    <div>      <label>选择:</label>      <input type='file' multiple id="file" />      <input type="button" value="文件上传" onClick="showFile()" />    </div>    <script>      function showFile() {        var files = document.getElementById('file').files;  // 返回所有被选择的文件        for (var i = 0, ilen = files.length; i < ilen; i++) {          // 打印出单个文件对象的信息          console.log(files[i]);                                      }      }    </script>  </body></html>

2. 理解Blob对象

要点:在HTML5中,新增一个Blob对象,代表原始二进制数据,其实file对象也是继承了Blob对象。

Blob对象有两个属性,size属性表示一个Blob对象的字节长度,type属性表示Blob的MIME类型,如果是未知类型,则返回一个空字符串

请看如下代码:

<!DOCTYPE html><html>  <head>    <title>filesystem:URL</title>  </head>  <body>    <div>      <label>选择文件:</label>      <input type="file" id="file" />      <input type="button" value="显示文件信息" onClick="showFileType()" />      <p>文件字节长度: <span id="size"></span></p>      <p>文件类型:<span id="type"></span></p>    </div>    <script>      function showFileType() {        var file;        // 获取用户选择的第一个文件        file = document.getElementById('file').files[0];        var size = document.getElementById('size');        var type = document.getElementById('type');        // 显示文件字节的长度        size.innerHTML = file.size;        // 显示文件的类型        type.innerHTML = file.type;        // 打开控制台 查看返回的file对象        console.log(file);      }    </script>      </body></html>

注意:Blob和File是可以同时使用的,可以使用FileReader从Blob中读取数据。

下面是一段绝对路径的图片地址转换为base64编码的图片,然后将base64编码的图片转换成blob对象。代码如下:

<!DOCTYPE html><html>  <head>    <title>将以base64的图片url数据转换为Blob</title>  </head>  <body>    <script>              function convertBase64UrlToBlob(base64){         var urlData =  base64.dataURL;        var type = base64.type;        var bytes = window.atob(urlData.split(',')[1]); //去掉url的头,并转换为byte        //处理异常,将ascii码小于0的转换为大于0          var ab = new ArrayBuffer(bytes.length);          var ia = new Uint8Array(ab);          for (var i = 0; i < bytes.length; i++) {              ia[i] = bytes.charCodeAt(i);          }          return new Blob( [ab] , {type : type});        }            function getBase64Image(img) {        var canvas = document.createElement("canvas");        canvas.width = img.width;        canvas.height = img.height;        var ctx = canvas.getContext("2d");        ctx.drawImage(img, 0, 0, img.width, img.height);        var ext = img.src.substring(img.src.lastIndexOf(".")+1).toLowerCase();        var dataURL = canvas.toDataURL("image/"+ext);        return {          dataURL: dataURL,          type: "image/"+ext        };      }      var img = "https://file.lsjlt.com/upload/202306/07/kqvv0e53ovq.jpg";      var image = new Image();      image.crossOrigin = '';      image.src = img;      image.onload = function(){        var base64 = getBase64Image(image);        console.log(base64);                var img2 = convertBase64UrlToBlob(base64);        console.log(img2);              }     </script>  </body></html>

注意:在HTML5中,新增一个Blob对象,代表原始二进制数据,其实file对象也是继承了Blob对象。因此我们可以使用图片的绝对地址转换成文件对象。

因此我们可以使用绝对地址的图片转换成file文件对象,详细的demo可以看我git上图片上传控件,该插件先是图片上传支持,然后突然发现到编辑页面的时候,需要显示默认的图片,也可以同时支持在默认显示图片的情况下继续上传新图片,或者删除所有的图片,但是开发人员给我的只有图片的绝对地址,所以就一直想通过图片的绝对地址如何转换成file对象,如果不转成file对象的话,使用这句代码的时候 var reader = new FileReader(); 会报错,因此可以使用我们上面讲的blob对象先转换成blob对象,然后就可以使用文件操作对象 fileReader。

关于“html5中怎么将图片的绝对路径转换成文件对象”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: html5中怎么将图片的绝对路径转换成文件对象

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

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

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

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

下载Word文档
猜你喜欢
  • html5中怎么将图片的绝对路径转换成文件对象
    这篇文章将为大家详细讲解有关html5中怎么将图片的绝对路径转换成文件对象,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体如下:我们先来理解基本知识点:1. 理解HTML5中的FileList对象与fi...
    99+
    2023-06-09
  • php怎么将路径转换成实际路径(绝对地址)
    在php中,可以使用realpath()函数来将路径转换成实际路径,语法“realpath(path)”。realpath()函数可以接受一个文件的相对路径作为参数“path”的值,然后返回绝对路径(实际文件所在位置信息),该路径包含文件名...
    99+
    2022-06-14
    php文件目录 php
  • html中怎么把图片的绝对路径改成相对路径
    本篇内容介绍了“html中怎么把图片的绝对路径改成相对路径”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  首先要我们要弄懂相对路径修改成绝...
    99+
    2023-06-05
  • linux中怎么用shell获取文件的绝对路径
    在Linux中,可以使用shell脚本来获取文件的绝对路径。以下是几种常用的方法: 方法一:使用pwd命令获取当前工作目录的绝对路径...
    99+
    2023-10-28
    linux shell
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作