[转]html之file标签 --- 图片上传前预览 -- FileReader

记得以前做网站时,曾经需要实现一个图片上传到服务器前,先预览的功能。当时用html的<input type="file"/>标签一直实现不了,最后舍弃了这个标签,使用了其他方式来实现了这个功能。

  今天无意发现了一个知识点,用html的file标签就能实现图片上传前预览,感觉很棒,记录一下!就是通过file标签和js的FileReader接口,把选择的图片文件调用readAsDataURL方法,把图片数据转成base64字符串形式显示在页面上。

1、闲话少说,测试一下,图片上传前预览(选择图片):

代码:

<div style="border:2px dashed red;">
            <p>
                图片上传前预览:<input type="file" id="xdaTanFileImg" onchange="xmTanUploadImg(this)" accept="image/*"/>
                <input type="button" value="隐藏图片" onclick="document.getElementById(‘xmTanImg‘).style.display = ‘none‘;"/>
                <input type="button" value="显示图片" onclick="document.getElementById(‘xmTanImg‘).style.display = ‘block‘;"/>
            </p>
            <img id="xmTanImg"/>
            <div id="xmTanDiv"></div>
        </div>
        <hr />
        <script type="text/javascript">
            //判断浏览器是否支持FileReader接口
            if (typeof FileReader == ‘undefined‘) {
                document.getElementById("xmTanDiv").InnerHTML = "<h1>当前浏览器不支持FileReader接口</h1>";
                //使选择控件不可操作
                document.getElementById("xdaTanFileImg").setAttribute("disabled", "disabled");
            }

            //选择图片,马上预览
            function xmTanUploadImg(obj) {
                var file = obj.files[0];

                console.log(obj);console.log(file);
                console.log("file.size = " + file.size);  //file.size 单位为byte

                var reader = new FileReader();

                //读取文件过程方法
                reader.onloadstart = function (e) {
                    console.log("开始读取....");
                }
                reader.onprogress = function (e) {
                    console.log("正在读取中....");
                }
                reader.onabort = function (e) {
                    console.log("中断读取....");
                }
                reader.onerror = function (e) {
                    console.log("读取异常....");
                }
                reader.onload = function (e) {
                    console.log("成功读取....");

                    var img = document.getElementById("xmTanImg");
                    img.src = e.target.result;
                    //或者 img.src = this.result;  //e.target == this
                }

                reader.readAsDataURL(file)
            }
        </script>

-------------------------------  end  -----------------------------

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

测试一下,选择文本(txt、cs、html、js、css、xml),读取成二进制或者文本:

<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>

---------------------------

3、----------- a标签之download属性 -------------

   设置a标签href为图片链接,再设置download属性,点此链接可以直接下载图片

<div style="text-align:center; padding: 5px 20px;width: 70%;">
            <img id="xmTanShowImg" src=""/>
            <h1><a href="javascript:void()" download="girl.jpg" id="xmTanDownload">点此下载</a></h1>
        </div>
        <script type="text/javascript">
            //图片转成base64位字符串数据
            var imgData = "data:image/png;base64,.........";
            //或直接设置图片链接: var imgData = "images/picture.png";

            document.getElementById("xmTanShowImg").setAttribute("src", imgData);  //给图片标签设置src
            document.getElementById("xmTanDownload").setAttribute("href", imgData); //给a标签设置href
        </script>

原文链接:http://www.cnblogs.com/tandaxia/p/5125275.html

时间: 2024-08-02 02:45:03

[转]html之file标签 --- 图片上传前预览 -- FileReader的相关文章

html之file标签 --- 图片上传前预览 -- FileReader

记得以前做网站时,曾经需要实现一个图片上传到服务器前,先预览的功能.当时用html的<input type="file"/>标签一直实现不了,最后舍弃了这个标签,使用了其他方式来实现了这个功能. 今天无意发现了一个知识点,用html的file标签就能实现图片上传前预览,感觉很棒,记录一下!就是通过file标签和js的FileReader接口,把选择的图片文件调用readAsDataURL方法,把图片数据转成base64字符串形式显示在页面上. 1.闲话少说,测试一下,图片上

input file实现多选,限制文件上传类型,图片上传前预览功能

限制上传类型 & 多选:① accept 属性只能与 <input type="file" /> 配合使用.它规定能够通过文件上传进行提交的文件类型. ② multiple 属性规定输入字段可选择多个值. 示例: <!-- image/* 所有图片 image/png png图片 image/jpg jpg图片 image/gif gir动图 application/msword Word文档(.doc) application/vnd.openxmlform

HTML5 jQuery图片上传前预览

HTML5实现表单内的上传文件框,上传前预览图片,针刷新预览images,本例子主要是使用HTML5 的File API,建立一個可存取到该file的url,一个空的img标签,ID为img0,把选择的文件显示在img标签中,实现图片预览功能.请选择支持HTML API的浏览器,比如谷歌Chrome和火狐等. <!DOCTYPE html><html> <head> <title>HTML5上传图片预览</title> <meta char

【转】HTML5 jQuery图片上传前预览

hTML5实现表单内的上传文件框,上传前预览图片,针刷新预览images,本例子主要是使用HTML5 的File API,建立一個可存取到该 file的url,一个空的img标签,ID为img0,把选择的文件显示在img标签中,实现图片预览功能.请选择支持HTML API的浏览器,比如 谷歌Chrome和火狐等. <!DOCTYPE html> <html> <head> <title>HTML5上传图片预览</title> <meta h

图片上传前预览的功能

最近自己想做一个项目,涉及到很多图片上传和预览的功能,所以简单记录下: 这里我没有用vue的组件库,是单纯靠input来写出一个图片上传的功能. 思路是:先用input[type=file]来获取本地的图片,然后用HTML5的 File API 的 FileReader 图片本地转成base64格式的url,把这个url赋值到用于预览的src就好了. <div class="upload"> <div class="img-container"&g

HTML5 FileReader实现图片上传前预览

如果你的浏览器支持Html5的FileReader的话,实现图片上传前进行预览是一件非常容易之事情. 在控制器,创建一个视图Action: jQuery代码: 实时演示一下:

前端图片上传前预览

<!DOCTYPE html> <html> <head> <title>图片上传预览</title> <meta charset="utf-8"> <script type="text/javascript" src="jquery-1.8.3.min.js"></script> <script type="text/javascri

基于layUI的图片上传前预览功能的2种实现方式

上传页面采用了layui 的上传模块,要实现的功能:选择文件后---点击文件名,页面中间弹窗内预览图片,先看效果图: 预览功能的实现具体有2种方式:第一种是用blob+FileReader,第二种是layUI自带的. 1. 用layUI 自带的参数实现图片预览: layui.use('upload', function(){ ... choose: function(obj){ var files = this.files = obj.pushFile(); //将每次选择的文件追加到文件队列

图片上传前预览,两种方式可实现

表单提交,前端html: <img id="avatar" style="width: 220px;height: 230px;" alt="image" src="__AVATAR__/boy.png"/> <input id="image" name="image" type="file" style="display: none&qu