欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

html5中怎么將圖片的絕對(duì)路徑轉(zhuǎn)換成文件對(duì)象

這篇文章將為大家詳細(xì)講解有關(guān)html5中怎么將圖片的絕對(duì)路徑轉(zhuǎn)換成文件對(duì)象,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

成都創(chuàng)新互聯(lián)公司服務(wù)緊隨時(shí)代發(fā)展步伐,進(jìn)行技術(shù)革新和技術(shù)進(jìn)步,經(jīng)過(guò)十年的發(fā)展和積累,已經(jīng)匯集了一批資深網(wǎng)站策劃師、設(shè)計(jì)師、專(zhuān)業(yè)的網(wǎng)站實(shí)施團(tuán)隊(duì)以及高素質(zhì)售后服務(wù)人員,并且完全形成了一套成熟的業(yè)務(wù)流程,能夠完全依照客戶(hù)要求對(duì)網(wǎng)站進(jìn)行成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計(jì)、建設(shè)、維護(hù)、更新和改版,實(shí)現(xiàn)客戶(hù)網(wǎng)站對(duì)外宣傳展示的首要目的,并為客戶(hù)企業(yè)品牌互聯(lián)網(wǎng)化提供全面的解決方案。

具體如下:

我們先來(lái)理解基本知識(shí)點(diǎn):

1. 理解HTML5中的FileList對(duì)象與file對(duì)象。

在HTML5中,F(xiàn)ileList對(duì)象表示用戶(hù)選擇的文件列表。通過(guò)添加multipe屬性,file控件內(nèi)允許一次選擇多個(gè)文件??丶?nèi)的每一個(gè)用戶(hù)選擇的文件都是一個(gè)file對(duì)象,而FileList對(duì)象則是file對(duì)象的列表。代表用戶(hù)選擇的所有文件。我們先來(lái)看一個(gè)簡(jiǎn)單的demo,看下file文件對(duì)象有哪些屬性。如下代碼:

<!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++) {
          // 打印出單個(gè)文件對(duì)象的信息
          console.log(files[i]);
          /*  
           * 打印的信息如下:
           File {
            lastModified: 1457946612000
            lastModifiedDate: Mon Mar 14 2016 17:10:12 GMT+0800 (CST) {}
            name: "test.html"
            size: 796
            type: "text/html"
            webkitRelativePath: "" 
          */
          /*  如果上傳的是一張圖片的話,會(huì)返回如下信息的
            File {
              lastModified: 1466907500000
              lastModifiedDate: Sun Jun 26 2016 10:18:20 GMT+0800 (CST) {}
              name: "a.jpg"
              size: 23684
              type: "image/jpeg"
              webkitRelativePath: ""
            }
          */
          /*
           因此 如果需要判斷該上傳的文件是不是圖像文件的話,可以根據(jù)type類(lèi)型來(lái)判斷如下:
           var file = files[i];
           if (!/image\/\w+/.test(file.type)) {
              console.log('該文件不是圖像文件');
           } else {
              console.log('該文件是圖像文件');
           }

           但是如果只讓傳圖片的話,可以在image控件添加一個(gè)屬性 accept="image/*" 即可;我們可以如下寫(xiě)代碼:
           <input type='file' multiple accept = 'image/gif,image/jpeg,image/jpg,image/png' />
           */
        }
      }
    </script>
  </body>
</html>

2. 理解Blob對(duì)象

要點(diǎn):在HTML5中,新增一個(gè)Blob對(duì)象,代表原始二進(jìn)制數(shù)據(jù),其實(shí)file對(duì)象也是繼承了Blob對(duì)象。

Blob對(duì)象有兩個(gè)屬性,size屬性表示一個(gè)Blob對(duì)象的字節(jié)長(zhǎng)度,type屬性表示Blob的MIME類(lèi)型,如果是未知類(lèi)型,則返回一個(gè)空字符串。

請(qǐng)看如下代碼:

<!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>文件字節(jié)長(zhǎng)度: <span id="size"></span></p>
      <p>文件類(lèi)型:<span id="type"></span></p>
    </div>
    <script>
      function showFileType() {
        var file;
        // 獲取用戶(hù)選擇的第一個(gè)文件
        file = document.getElementById('file').files[0];
        var size = document.getElementById('size');
        var type = document.getElementById('type');
        // 顯示文件字節(jié)的長(zhǎng)度
        size.innerHTML = file.size;
        // 顯示文件的類(lèi)型
        type.innerHTML = file.type;

        // 打開(kāi)控制臺(tái) 查看返回的file對(duì)象
        console.log(file);
      }
    </script>
    
  </body>
</html>

注意:Blob和File是可以同時(shí)使用的,可以使用FileReader從Blob中讀取數(shù)據(jù)。

下面是一段絕對(duì)路徑的圖片地址轉(zhuǎn)換為base64編碼的圖片,然后將base64編碼的圖片轉(zhuǎn)換成blob對(duì)象。代碼如下:

<!DOCTYPE html>
<html>
  <head>
    <title>將以base64的圖片url數(shù)據(jù)轉(zhuǎn)換為Blob</title>
  </head>
  <body>
    <script>
      /**  
       * 將以base64的圖片url數(shù)據(jù)轉(zhuǎn)換為Blob  
       * @param urlData  
       * 用url方式表示的base64圖片數(shù)據(jù)  
       */  
      function convertBase64UrlToBlob(base64){ 
        var urlData =  base64.dataURL;
        var type = base64.type;
        var bytes = window.atob(urlData.split(',')[1]); //去掉url的頭,并轉(zhuǎn)換為byte
        //處理異常,將ascii碼小于0的轉(zhuǎn)換為大于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});  
      }
      /* 
       * 圖片的絕對(duì)路徑地址 轉(zhuǎn)換成base64編碼 如下代碼: 
       */
      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 = "/upload/otherpic69/133946.jpg";
      var image = new Image();
      image.crossOrigin = '';
      image.src = img;
      image.onload = function(){
        var base64 = getBase64Image(image);
        console.log(base64);
        /*
         打印信息如下:
         {
          dataURL: "data:image/png;base64,xxx"
          type: "image/jpg"
         }
         */
        var img2 = convertBase64UrlToBlob(base64);
        console.log(img2);
        /*
         打印信息如下:
         Blob {size: 9585, type: "image/jpg"}
         */
      } 
    </script>
  </body>
</html>

注意:在HTML5中,新增一個(gè)Blob對(duì)象,代表原始二進(jìn)制數(shù)據(jù),其實(shí)file對(duì)象也是繼承了Blob對(duì)象。因此我們可以使用圖片的絕對(duì)地址轉(zhuǎn)換成文件對(duì)象。

因此我們可以使用絕對(duì)地址的圖片轉(zhuǎn)換成file文件對(duì)象,詳細(xì)的demo可以看我git上圖片上傳控件,該插件先是圖片上傳支持,然后突然發(fā)現(xiàn)到編輯頁(yè)面的時(shí)候,需要顯示默認(rèn)的圖片,也可以同時(shí)支持在默認(rèn)顯示圖片的情況下繼續(xù)上傳新圖片,或者刪除所有的圖片,但是開(kāi)發(fā)人員給我的只有圖片的絕對(duì)地址,所以就一直想通過(guò)圖片的絕對(duì)地址如何轉(zhuǎn)換成file對(duì)象,如果不轉(zhuǎn)成file對(duì)象的話,使用這句代碼的時(shí)候 var reader = new FileReader(); 會(huì)報(bào)錯(cuò),因此可以使用我們上面講的blob對(duì)象先轉(zhuǎn)換成blob對(duì)象,然后就可以使用文件操作對(duì)象 fileReader。

關(guān)于“html5中怎么將圖片的絕對(duì)路徑轉(zhuǎn)換成文件對(duì)象”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

本文題目:html5中怎么將圖片的絕對(duì)路徑轉(zhuǎn)換成文件對(duì)象
文章源于:http://aaarwkj.com/article40/pdicho.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、品牌網(wǎng)站制作、服務(wù)器托管、靜態(tài)網(wǎng)站、面包屑導(dǎo)航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設(shè)
精品传媒国产在线观看| 青青草青娱乐免费在线视频 | 亚洲国产免费一区二区| 国产成人亚洲综合色影视| 国产国语网站在线观看| 精品久久久噜噜噜久久| 最新日韩精品电影在线网| 开裆丝袜高跟啪啪高潮av| 日韩不卡免费一区二区三区视频| av基地蜜桃蜜桃蜜桃| 免费在线一区二区av| 日韩精品中文女同在线播放| 青草成人在线视频观看| 女人的天堂av免费在线观看| av天堂官网在线人妻| 亚洲国产成人综合一区二区三区| 中文字幕日韩精品在线看| 欧美精品日韩中文字幕在| 蜜臀国产综合久久第一页| 亚洲中文字幕女同系列av专区| 中国女人内射91熟女| 88国产精品久久久久久| 少妇高潮惨叫久久麻豆传| 国产精品国产成人免费看| 亚洲七七久久精品中文国产| 日韩中文字幕一二三| 亚洲欧美另类国产一区| 无套内射精品一区二区| 日韩欧美另类精品在线| 亚洲奇米精品一区二区| 丰满的熟妇女教师水多| 久久成人av一区二区三区| 久久精品视频视频视频| 成人av高清在线观看| 中文字幕在线五月婷婷| 白虎亚洲福利精品一区| 人妻一区二区三区中文字幕| 国产日韩传媒在线观看| 国产欧美又粗又猛又爽老| 亚洲激情午夜福利视频| 成人爱爱免费观看视频|