乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      使用FileReader對(duì)象的readAsDataURL方法來(lái)讀取圖像文件

       leong 2018-04-26


      FileReader對(duì)象的readAsDataURL方法可以將讀取到的文件編碼成Data URL。Data URL是一項(xiàng)特殊的技術(shù),可以將資料(例如圖片)內(nèi)嵌在網(wǎng)頁(yè)之中,不用放到外部文件。使用Data URL的好處是,您不需要額外再發(fā)出一個(gè)HTTP 請(qǐng)求到服務(wù)器端取得額外的資料;而缺點(diǎn)便是,網(wǎng)頁(yè)的大小可能會(huì)變大。它適合應(yīng)用在內(nèi)嵌小圖片,不建議將大圖像文件編碼成Data URL來(lái)使用。您的圖像文件不能夠超過(guò)瀏覽器限定的大小,否則無(wú)法讀取圖像文件。

      參考以下使用readAsDataURL讀取圖像文件范例:

      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      16
      17
      18
      19
      20
      21
      22
      23
      24
      25
      26
      27
      28
      29
      <!DOCTYPE html>
      <html xmlns = "http://www./1999/xhtml" >
      <head>
          <title> </title>
          <script type = "text/javascript" >
              function ProcessFile( e ) {
                  var file = document.getElementById('file').files[0];
                  if (file) {
                      
                      var reader = new FileReader();
                      reader.onload = function ( event ) {
                          var txt = event.target.result;
                          document.getElementById("result").innerHTML = txt;
                          };
                    }
                  reader.readAsDataURL( file );
                  }
              function contentLoaded () {
                  document.getElementById('file').addEventListener( 'change' ,
      ProcessFile , false );
              }
              window.addEventListener( "DOMContentLoaded" , contentLoaded , false );
          </script>
      </head>
      <body>
         請(qǐng)選取一個(gè)圖像文件: <input type = "file" id = "file" name = "file" />
         <div id = "result"> </div>
      </body>
      </html>

       

      readAsDataURL方法會(huì)使用base-64進(jìn)行編碼,編碼的資料由data字串開(kāi)始,后面跟隨的是MIME type,然后再加上base64字串,逗號(hào)之后就是編碼過(guò)的圖像文件的內(nèi)容。

      使用Img顯示圖像文件

       

      若想要將讀取出來(lái)的圖像文件,直接顯示在網(wǎng)頁(yè)上,您可以透過(guò)JavaScript建立一個(gè)<img>標(biāo)簽,再設(shè)定src屬性為Data URL,再將<img>標(biāo)簽加入DOM之中,例如以下范例所示:

       

      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      16
      17
      18
      19
      20
      21
      22
      23
      24
      25
      26
      27
      28
      29
      30
      31
      <!DOCTYPE html>
      <html xmlns = "http://www./1999/xhtml" >
      <head>
      <title> </title>
      <script type = "text/javascript" >
      function ProcessFile( e ) {
      var file = document.getElementById('file').files[0];
      if ( file ) {
      var reader = new FileReader();
      reader.onload = function ( event ) {
      var txt = event.target.result;
      var img = document.createElement("img");
      img.src = txt;
      document.getElementById("result").appendChild( img );
      };
      }
      reader.readAsDataURL( file );
      }
      function contentLoaded() {
      document.getElementById('file').addEventListener( 'change' ,
      ProcessFile , false );
      }
      window.addEventListener( "DOMContentLoaded" , contentLoaded , false );
      </script>
      </head>
      <body>
      請(qǐng)選取一個(gè)圖像文件: <input type = "file" id = "file" name = "file" />
      <div id = "result"> </div>
      </body>
      </html>

      讀取部分文件

      有時(shí)想要讀取的文件太大,想要分段進(jìn)行讀?。换蛘咧幌胍x取文件部分的內(nèi)容,這時(shí)您可以將文件切割,根據(jù)瀏覽器的不同,可以使用以下方法:

      webkitSlice:適用于支持Webkit引擎的瀏覽器,如Chrome。
      mozSlice:適用于Firefox。

      這兩個(gè)方法要傳入開(kāi)始的位元組索引,以及結(jié)尾的位元組索引,索引以0開(kāi)始。以下程式范例以FileReader對(duì)象的readAsBinaryString方法來(lái)讀取文件,只讀取文件的第三個(gè)位元組讀取到第六個(gè)位元組:

      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      16
      17
      18
      19
      20
      21
      22
      23
      24
      25
      26
      27
      28
      29
      30
      31
      32
      33
      <!DOCTYPE html>
      <html xmlns ="http://www./1999/xhtml" >
      <head>
      <title> </title>
      <script type = "text/javascript" >
      function ProcessFile( e ) {
      var file = document.getElementById( 'file' ).files[0];
      if ( file ) {
      var reader = new FileReader ();
      reader.onload = function ( event ) {
      var txt = event.target.result;
      document.getElementById( "result" ).innerHTML = txt;
      };
      }
      if ( file.webkitSlice ) {
      var blob = file.webkitSlice( 2, 4 );
      } else if ( file.mozSlice ) {
      var blob = file.mozSlice( 2, 4 );
      }
      reader.readAsBinaryString( blob );
      }
      function contentLoaded() {
      document.getElementById( 'file' ).addEventListener( 'change' ,
      ProcessFile , false );
      }
      window.addEventListener( "DOMContentLoaded", contentLoaded , false );
      </script>
      </head>
      <body>
      <input type = "file" id = "file" name = "file" />
      <div id = "result" > </div>
      </body>
      </html>


      請(qǐng)注意:
      不同的瀏覽器對(duì)于HTML 5的支持程度不同,上述程式碼可在chrome正常執(zhí)行,不見(jiàn)得可以在其它瀏覽器中正確的執(zhí)行。

        本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評(píng)論

        發(fā)表

        請(qǐng)遵守用戶 評(píng)論公約

        類似文章 更多