天天看點

原生 js 實作截圖粘貼預覽圖檔功能

效果

比如我截圖我的資訊

原生 js 實作截圖粘貼預覽圖檔功能

然後粘貼到區域裡,就能預覽這個圖檔

原生 js 實作截圖粘貼預覽圖檔功能

代碼實作

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>截圖粘貼預覽圖檔</title>

    <style>div.preview-img {
            border: 2px solid #ddd;
            margin: .5rem;
            padding: .5rem;
            min-height: 30rem;
            border-radius: 10px;
            background-color: #fff;
        }</style>
</head>
<body>
    <h1 style="text-align: center;">kaimo 測試截圖粘貼預覽圖檔功能,請在下面容器進行粘貼</h1>
    <div class="preview-img"></div>
    <script>// 監聽粘貼事件
        const target = document.querySelector("div.preview-img");

        target.addEventListener("paste", (event) => {
            event.preventDefault();
            let paste = event.clipboardData || window.clipboardData;
            // 找到圖檔檔案file
            if(paste.files && paste.files.length > 0 && paste.files[0].type === "image/png") {
                let fr = new FileReader();
                // 讀取 file 然後傳回 data:URL 格式的字元串(base64 編碼)以表示所讀取檔案的内容。
                fr.readAsDataURL(paste.files[0]);
                fr.onload = function(e) {
                    let img = document.createElement("img");
                    img.src = e.target.result;
                    target.innerHTML = "";
                    target.appendChild(img);
                } 
            }else{
                alert("請截圖粘貼");
            }
        });</script>
</body>
</html>      

參考資料

  • ​​FileReader.readAsDataURL()​​
  • ​​Element: paste 事件​​

繼續閱讀