发表于: 2017-06-27 23:01:13

1 926


今天完成的事情:实现了一个还没有上传之前在线预览图片的效果,学会了url传参,整理了代码

明天计划的事情:金超师兄说我的代码结构有问题,准备修改,顺便修改代码逻辑,因为以前没有使用state.go,而是直接刷新数据,导致不能实现url传参,修改中

遇到的问题:可能要重写逻辑

收获:任务8要实现url传参就必须要用state.go,希望后面的师弟不会走错路吧。

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

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

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


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



返回列表 返回列表
评论

    分享到