FileReader除了有函数readAsDataURL,另外还有另外两个函数readAsBinaryString 和 readAsText,分别可以将选择的文件读取成二进制和文本格式

来源:互联网 发布:win7网络发现打不开 编辑:程序博客网 时间:2024/06/05 00:59
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    
<script type="text/javascript">
            //判断浏览器是否支持FileReader接口
            if (typeof FileReader == 'undefined') {
                document.getElementById("xmTanContentDiv").InnerHTML = "<p>当前浏览器不支持FileReader接口!</p>";
                document.getElementById("xmTanFile").setAttribute("disabled", "disabled");
            }
            //选择文件
            function xmTanUploadFile(obj){
                if (obj.files.length < 1) return;
                var file = obj.files[0];
                
                if (file.size > 1024 * 1024) {
                    alert("文件大于1M, 太大了,小点吧!");
                    obj.value = "";
                    return;
                }
            }
            //读取文件为二进制
            function readAsBinaryString() {
                var obj = document.getElementById("xmTanFile");
                if (obj.files.length < 1) return;


                var file = obj.files[0];
                var reader = new FileReader();


                //将文件以二进制形式读入页面
                reader.readAsBinaryString(file);
                reader.onload = function (f) {
                    document.getElementById("xmTanContentDiv").innerHTML = this.result;
                }
            }

            //读取文件为文本
            function readAsText() {
                var obj = document.getElementById("xmTanFile");
                if (obj.files.length < 1) return;
                var file = obj.files[0];
                var reader = new FileReader();
                //将文件以文本形式读入页面
                reader.readAsText(file);
                reader.onload = function (f) {
                    document.getElementById("xmTanContentDiv").innerHTML = this.result;
                }
            }
        </script>
        <div style="border: 2px dashed red; padding: 20px 0px;">
            <label>选择文件:</label>
            <input type="file" id="xmTanFile" accept=".html,.js,.css,.txt,.cs,.xml" onchange="xmTanUploadFile(this)"/>
            <input type="button" value="读取成二进制数据" onclick="readAsBinaryString()" />
            <input type="button" value="读取成文本数据" onclick="readAsText()" />
            <input type="button" value="隐藏读取内容" onclick="document.getElementById('xmTanContentDiv').style.display = 'none';"/>
            <input type="button" value="显示读取内容" onclick="document.getElementById('xmTanContentDiv').style.display = 'block';"/>
            <div id="xmTanContentDiv"></div>
        </div>  
</body>
</html>

阅读全文
0 0
原创粉丝点击