zoukankan      html  css  js  c++  java
  • input type=file 选择图片并且实现预览效果的实例

    为大家带来一篇input type=file 选择图片并且实现预览效果的实例。

    通过<input />标签,给它指定type类型为file,可提供文件上传;

    accept:可选择上传类型,如:只要传图片,且不限制图片格式,为image/*;

    multiple:规定是否可以选择多个文件;

    规定只可上传图片,且可以选择多个文件

    <input type="file" accept="image/*" multiple="multiple"/>

     

    当然,直接一个input type=file 只能选择上传的文件/资源,如果我们需要在选择图片之后,在当前页面实现预览效果,那么我们可以如下方式来实现

    <body>
        <style>
            #box {
                width: 300px;
                height: 300px;
                border: 2px solid #858585;
            }
    
            #imgshow {
                width: 100%;
                height: 100%;
            }
    
            #pox {
                width: 70px;
                height: 24px;
                overflow: hidden;
            }
        </style>
        <div id="box">
            <img id="imgshow" src="" alt="" />
        </div>
        <div id="pox">
            <input id="filed" type="file" accept="image/*" />
        </div>
        <script language="JavaScript" src="http://libs.baidu.com/jquery/2.1.1/jquery.min.js?rand=1525249087392"></script>
        <script>
            $(document).ready(function () {
                //在input file内容改变的时候触发事件
                $('#filed').change(function () {
                    //获取input file的files文件数组;
                    //$('#filed')获取的是jQuery对象,.get(0)转为原生对象;
                    //这边默认只能选一个,但是存放形式仍然是数组,所以取第一个元素使用[0];
                    var file = $('#filed').get(0).files[0];
                    //创建用来读取此文件的对象
                    var reader = new FileReader();
                    //使用该对象读取file文件
                    reader.readAsDataURL(file);
                    //读取文件成功后执行的方法函数
                    reader.onload = function (e) {
                        //读取成功后返回的一个参数e,整个的一个进度事件
                        console.log(e);
                        //选择所要显示图片的img,要赋值给img的src就是e中target下result里面
                        //的base64编码格式的地址
                        $('#imgshow').get(0).src = e.target.result;
                    }
                })
            });
        </script>
    </body>
  • 相关阅读:
    php基本语法与安装
    面向对象编程 es5和es6的构造函数
    利用正则搜索替换
    正则特殊符号
    正则边界符 限定符
    面试官给我挖坑:rm删除文件之后,空间就被释放了吗?
    为什么 IPv6 难以取代 IPv4
    Docker系列教程04-Docker构建镜像的三种方式
    Docker系列教程03-Docker私有仓库搭建(registry)
    Linux-I/O模型详解
  • 原文地址:https://www.cnblogs.com/suizhikuo/p/8980945.html
Copyright © 2011-2022 走看看