1. 程式人生 > >Web API介面 FileReader學習筆記

Web API介面 FileReader學習筆記

FileReader 物件允許Web應用程式非同步讀取儲存在使用者計算機上的檔案(或原始資料緩衝區)的內容,使用 File 或 Blob 物件指定要讀取的檔案或資料。

一、介紹

FileReader介面的方法

FileReader介面有4個方法,其中3個用來讀取檔案,另一個用來中斷讀取。無論讀取成功或失敗,方法並不會返回讀取結果,這一結果儲存在result屬性中。

這裡寫圖片描述

FileReader介面事件

FileReader介面包含了一套完整的事件模型,用於捕獲讀取檔案時的狀態;
這裡寫圖片描述

屬性

這裡寫圖片描述

狀態常量

這裡寫圖片描述

二、使用

下面是幾個例項,第一個演示了三種不同讀取圖片檔案的方法,第二個例項其實是第一個例項中將檔案讀取為data url的翻版;最後一個例項,是對不支援FileReader物件的瀏覽器的相容性擴充套件方法,即針對IE10以下的瀏覽器,我們通過使用濾鏡來相容舊版本的IE;

例項-1:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>

<div>
    <label for="">請選擇一個圖片檔案</label>
    <input type="file" id="file" />
    <input type="button" value="讀取圖片"
onclick="readAsDataURL()" />
<input type="button" value="讀取二進位制資料" onclick="readAsBinaryString()" /> <input type="button" value="讀取文字檔案" onclick="readAsText()" /> </div> <div id="result" name="result"></div> <script type="text/javascript"> var result = document.getElementById("result"
); var file = document.getElementById("file"); //判斷瀏覽器是否支援FileReader介面 if(typeof FileReader == 'undefined'){ result.InnerHTML="<p>你的瀏覽器不支援FileReader介面!</p>"; // alert('你的瀏覽器不支援FileReader介面!') // 並把選擇控制元件設定成不可操作 file.setAttribute("disabled", "disabled"); } // 將檔案讀取為DataURL function readAsDataURL(){ // 檢驗是否為影象檔案 var file = document.getElementById("file").files[0]; if(!/image\/\w+/.test(file.type)){ alert("看清楚,這個需要圖片!"); return false; } var reader = new FileReader(); // 例項化一個FileReader介面 reader.readAsDataURL(file); // 呼叫FileReader介面的readAsDataURl方法,將檔案以Data URL形式讀入頁面 reader.onload = function(e){ // 繫結onload事件,當讀取完成時觸發 var result=document.getElementById("result"); //顯示檔案 result.innerHTML='<img src="' + this.result +'" alt="" />'; } } // 將檔案讀取為二進位制編碼 function readAsBinaryString(){ var file = document.getElementById("file").files[0]; var reader = new FileReader(); reader.readAsBinaryString(file); // 將檔案以二進位制形式讀入頁面 reader.onload = function(e){ var result = document.getElementById("result"); result.innerHTML = this.result; // 顯示選中的檔案 } } // 將檔案讀取為文字 function readAsText(){ var file = document.getElementById("file").files[0]; var reader = new FileReader(); reader.readAsText(file); // 將檔案以文字形式讀入頁面 reader.onload = function(e){ var result = document.getElementById("result"); result.innerHTML=this.result; // 顯示檔案 } }
</script> </body> </html>

執行截圖:
這裡寫圖片描述

例項-2:
線上演示-demo

<!doctype html>
<html>
<head>
    <meta content="text/html; charset=UTF-8" http-equiv="Content-Type" />
    <title>Image preview example</title>
    <script type="text/javascript">
            oFReader = new FileReader(), rFilter = /^(?:image\/bmp|image\/cis\-cod|image\/gif|image\/ief|image\/jpeg|image\/jpeg|image\/jpeg|image\/pipeg|image\/png|image\/svg\+xml|image\/tiff|image\/x\-cmu\-raster|image\/x\-cmx|image\/x\-icon|image\/x\-portable\-anymap|image\/x\-portable\-bitmap|image\/x\-portable\-graymap|image\/x\-portable\-pixmap|image\/x\-rgb|image\/x\-xbitmap|image\/x\-xpixmap|image\/x\-xwindowdump)$/i;

            oFReader.onload = function (oFREvent) {
                document.getElementById("uploadPreview").src = oFREvent.target.result;
            };

            function loadImageFile() {
                if (document.getElementById("uploadImage").files.length === 0) { return; }
                var oFile = document.getElementById("uploadImage").files[0];
                if (!rFilter.test(oFile.type)) { alert("You must select a valid image file!"); return; }
                oFReader.readAsDataURL(oFile);
            }
    </script>
</head>

<body onload="loadImageFile();">
<form name="uploadForm">
    <table>
        <tbody>
        <tr>
            <td><img id="uploadPreview" style="width: 100px; height: 100px;" src="data:image/svg+xml,%3C%3Fxml%20version%3D%221.0%22%3F%3E%0A%3Csvg%20width%3D%22153%22%20height%3D%22153%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%0A%20%3Cg%3E%0A%20%20%3Ctitle%3ENo%20image%3C/title%3E%0A%20%20%3Crect%20id%3D%22externRect%22%20height%3D%22150%22%20width%3D%22150%22%20y%3D%221.5%22%20x%3D%221.500024%22%20stroke-width%3D%223%22%20stroke%3D%22%23666666%22%20fill%3D%22%23e1e1e1%22/%3E%0A%20%20%3Ctext%20transform%3D%22matrix%286.66667%2C%200%2C%200%2C%206.66667%2C%20-960.5%2C%20-1099.33%29%22%20xml%3Aspace%3D%22preserve%22%20text-anchor%3D%22middle%22%20font-family%3D%22Fantasy%22%20font-size%3D%2214%22%20id%3D%22questionMark%22%20y%3D%22181.249569%22%20x%3D%22155.549819%22%20stroke-width%3D%220%22%20stroke%3D%22%23666666%22%20fill%3D%22%23000000%22%3E%3F%3C/text%3E%0A%20%3C/g%3E%0A%3C/svg%3E" alt="Image preview" /></td>
            <td><input id="uploadImage" type="file" name="myPhoto" onchange="loadImageFile();" /></td>
        </tr>
        </tbody>
    </table>

    <p><input type="submit" value="Send" /></p>
</form>
</body>
</html>

執行截圖:
這裡寫圖片描述

注: IE10以下的版本不支援FileReader()建構函式, 不過可以利用濾鏡來相容舊版本的IE

例項-3: 相容IE的圖片本地預覽.
線上演示——Demo

<!doctype html>
<html>
<head>
    <meta content="text/html; charset=UTF-8" http-equiv="Content-Type" />
    <title>Image preview example</title>
    <style type="text/css">
        #imagePreview {
            width: 160px;
            height: 120px;
            float: left;
            filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale);
        }
    </style>
</head>

<body>
    <div id="imagePreview"></div>

    <form name="uploadForm">
        <p>
            <input id="imageInput" type="file" name="myPhoto" onchange="loadImageFile();" /><br />
            <input type="submit" value="Send" />
        </p>
    </form>

    <script type="text/javascript">
        var loadImageFile = (function () {
            if (window.FileReader) {
                var oPreviewImg = null, oFReader = new window.FileReader(),
                    rFilter = /^(?:image\/bmp|image\/cis\-cod|image\/gif|image\/ief|image\/jpeg|image\/jpeg|image\/jpeg|image\/pipeg|image\/png|image\/svg\+xml|image\/tiff|image\/x\-cmu\-raster|image\/x\-cmx|image\/x\-icon|image\/x\-portable\-anymap|image\/x\-portable\-bitmap|image\/x\-portable\-graymap|image\/x\-portable\-pixmap|image\/x\-rgb|image\/x\-xbitmap|image\/x\-xpixmap|image\/x\-xwindowdump)$/i;

                oFReader.onload = function (oFREvent) {
                    if (!oPreviewImg) {
                        var newPreview = document.getElementById("imagePreview");
                        oPreviewImg = new Image();
                        oPreviewImg.style.width = (newPreview.offsetWidth).toString() + "px";
                        oPreviewImg.style.height = (newPreview.offsetHeight).toString() + "px";
                        newPreview.appendChild(oPreviewImg);
                    }
                    oPreviewImg.src = oFREvent.target.result;
                };

                return function () {
                    var aFiles = document.getElementById("imageInput").files;
                    if (aFiles.length === 0) { return; }
                    if (!rFilter.test(aFiles[0].type)) { alert("You must select a valid image file!"); return; }
                    oFReader.readAsDataURL(aFiles[0]);
                }

            }
            if (navigator.appName === "Microsoft Internet Explorer") {
                return function () {
                    document.getElementById("imagePreview").filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = document.getElementById("imageInput").value;

                }
            }
        })();
    </script>
</body>
</html>

執行截圖:
這裡寫圖片描述

參考閱讀: