HTML5實現拖拽讀取圖片檔案(將電腦中圖片拖入瀏覽器並顯示)

來源:互聯網
上載者:User

下面範例示範上傳圖片預覽功能。圖片的選擇,除了可以使用檔案上傳控制項選擇圖片,也可以直接把圖片拖放到虛線框中。


 
1,實現原理
(1)為了處理放置檔案的操作,需要處理三個事件:ondragenter、ondragover和ondrop。
(2)處理圖片用的是 readAsDataURL() 方法,其得到的資料URL是一種用長字串表示圖片的方式。為了在網頁中顯示圖片,可以將 <img> 元素的src屬性設定為圖片URL,也可也將CSS的 background-image 屬性設定為圖片URL(本例採用此方式)
(3)這裡將顯示圖片的<div>的 background-size 設為100%,為了縮小圖片以全部顯示。並將 background-repeat 設為 no-repeat,不讓圖片重複顯示。


<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>Read Image</title>
  <style>
    #dropBox {
      margin: 15px;
      width: 250px;
      height: 250px;
      border: 5px dashed gray;
      border-radius: 8px;
      background: lightyellow;
      background-size: 100%;
      background-repeat: no-repeat;
      text-align: center;
    }
      
    #dropBox div {
      margin: 75px 45px;
      color: orange;
      font-size: 25px;
      font-family: Verdana, Arial, sans-serif;
    }
 
    input {
      margin: 15px;
    }
  </style>
 
  <script>
    var dropBox;
 
    window.onload = function() {
      dropBox = document.getElementById("dropBox");
      dropBox.ondragenter = ignoreDrag;
      dropBox.ondragover = ignoreDrag;
      dropBox.ondrop = drop;
    }
 
    function ignoreDrag(e) {
      //因為我們在處理拖放,所以應該確保沒有其他元素會取得這個事件
      e.stopPropagation();
      e.preventDefault();
    }
 
    function drop(e) {
      //取消事件傳播及預設行為
      e.stopPropagation();
      e.preventDefault();
      
      //取得拖進來的檔案
      var data = e.dataTransfer;
      var files = data.files;
      //將其傳給真正的處理檔案的函數
      processFiles(files);
    }
 
    function processFiles(files) {
      var file = files[0];
      var output = document.getElementById("fileOutput");
      //建立FileReader
      var reader = new FileReader();
      //告訴它在準備好資料之後做什麼
      reader.onload = function (e) {
        //使用映像URL來繪製dropBox的背景
        dropBox.style.backgroundImage = "url('" + e.target.result + "')";
      };
      //讀取圖片
      reader.readAsDataURL(file);
    }
 
    function showFileInput() {
      var fileInput = document.getElementById("fileInput");
      fileInput.click();
    }
  </script>
</head>
 
<body>
    <div id="dropBox">
      <div>將圖片拖放到此處...</div>
    </div>
    <input id="fileInput" type="file" onchange="processFiles(this.files)">
    <img id="thumbnail">
</body>
</html>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.