Html5 input[type='file'] 把图片转换成base64

本文介绍了一种使用JavaScript处理用户上传的图片文件的方法。该方法通过读取文件为Base64编码,创建图片对象并获取尺寸信息,然后将图片绘制到Canvas上,最后返回包含原始URL和Base64编码的图片数据。

开发板推荐:天空星STM32F407VET6开发板

超高性价比 STM32主控 | 超高主频 | 一板兼容百芯 | 比赛神器 | 沉金彩色丝印

  function _addImgFileListener(obj, fun)
    {
        $(obj).change(function ()
        {
            try
            {
                var file = this.files[0];
                var reader = new FileReader();
                reader.onload = function ()
                {
                    var img = new Image();
                    img.src = reader.result;
                    img.onload = function ()
                    {
                        var w = img.width, h = img.height;
                        var canvas = document.createElement('canvas');
                        var ctx = canvas.getContext('2d');
                        $(canvas).attr({
                            width: w,
                            height: h
                        });
                        ctx.drawImage(img, 0, 0, w, h);
                        var base64 = canvas.toDataURL('image/jpeg', 0.5);
                        var result = {
                            url: window.URL.createObjectURL(file),
                            base64: base64,
                            clearBase64: base64.substr(base64.indexOf(',') + 1),
                            suffix: base64.substring(base64.indexOf('/') + 1, base64.indexOf(';')),
                        };
                        fun(result);
                    }
                }
                reader.readAsDataURL(this.files[0]);
            } catch (e)
            {
                _showMsg(e);
            }
        });

    }

$(document).ready(function(){

_addImgFileListener("#uploadimg",function(data)

{

    //你的业务

}

);

})

<input type="file" class="uploading" name="file" id="uploadimg" accept="image/jpg,image/jpeg,image/gif,image/png">

开发板推荐:天空星STM32F407VET6开发板

超高性价比 STM32主控 | 超高主频 | 一板兼容百芯 | 比赛神器 | 沉金彩色丝印

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值