Welcome to the website navigation,本站只接受合法正规的企业网站,欢迎站长们提交你的网站获得展示和流量有任何问题请联系站长,欢迎大家加入本站。

                
提交网站
  • 网站:76083
  • 待审:5
  • APP:577
  • 文章:304416
  • 会员:56004
文字内链包年1000元 文字内链包年1000元 文字内链包年1000元 AI办公网站 AI绘画工具 AIchat

名站导航为爱好css的朋友们提供相关的知识。

移动web如何实现类似客户端多方框输入密码功能neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

不知道怎么描述标题,先看截图吧,大致的效果就是一个框输入一位密码。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

  • 此篇文章具体介绍如下

上篇文章中提到移动端上传图片,我们知道现在流量还是挺贵的,手机的像素是越来越高,拍个照动不动就是好几M,伤不起。虽然客户端可以轻轻松松实现图片压缩再上传,但是我们的应用还可能在浏览器里面打开,怎么办呢,图片压缩。受以前PC上的开发思维影响,尼玛js哪有权限去操作文件,哪有资格压缩图片啊,搞不了,你们客户端去整吧。只能说自己还是有些井底之蛙了。在hTML5的影响下,前端能干的事情越来越多了,开发的功能逼格也越来越高了,h5万岁!前端的魅力也在这,过去不可能的并不意味现在、以后不可能,努力吧,骚年!neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

js怎么压缩图片???潜意识里确实一开始是觉得实现不了,后来翻阅资料,研究了下,发现可行!搞起!neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

先说说h5以前我们怎么上传,一般是借助插件、flash或者干脆一个文件form表单,少操不少心。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

自从有了h5,老板再也不担心我的开发了。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

上篇文章提到图片上传用到了FileReader,FormData,实际上主要用这两个我们基本能实现图片的预览和上传了。实现图片压缩,我们需要借助canvas,是的,就是canvas!neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

大致思路是:neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

1、创建一个图片和一个canvasneTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

var image = new Image(),   
canvas = document.createElement("canvas"),   
ctx = canvas.getContext('2d'); 

2、我们将input中选择的图片地址通过FileReader获取后赋给新建的图片对象,然后将图片对象丢到canvas画布上。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

var file = obj.files[0];   
                        var reader = new FileReader();//读取客户端上的文件   
                        reader.onload = function() {   
                            var url = reader.result;//读取到的文件内容.这个属性只在读取操作完成之后才有效,并且数据的格式取决于读取操作是由哪个方法发起的.所以必须使用reader.onload,   
                            image.src=url;//reader读取的文件内容是base64,利用这个url就能实现上传前预览图片   
                            ...   
                        };   
                        image.onload = function() {   
                            var w = image.naturalWidth,   
                                h = image.naturalheight;   
                            canvas.width = w;   
                            canvas.height = h;   
                            ctx.drawImage(image, 0, 0, w, h, 0, 0, w, h);   
                            fileUpload();   
                        };   
                        reader.readAsDataURL(file);  

这里需要注意的是,canvas将图片画到画布上的时候需要确定canvas的尺寸,同时设定好drawImage的参数,具体如下:neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

void ctx.drawImage(image, sx, sy, sWidth, sheight, dx, dy, dWidth, dheight);

dx源图像的左上角在目标canvas上 X 轴的位置。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

dy源图像的左上角在目标canvas上 Y 轴的位置。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

dWidth在目标canvas上绘制图像的宽度。 允许对绘制的图像进行缩放。 如果不说明, 在绘制时图片宽度不会缩放。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

dheight在目标canvas上绘制图像的高度。 允许对绘制的图像进行缩放。 如果不说明, 在绘制时图片高度不会缩放。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

sx需要绘制到目标上下文中的,源图像的矩形选择框的左上角 X 坐标。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

sy需要绘制到目标上下文中的,源图像的矩形选择框的左上角 Y 坐标。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

sWidth需要绘制到目标上下文中的,源图像的矩形选择框的宽度。如果不说明,整个矩形从坐标的sx和sy开始,到图像的右下角结束。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

sheight需要绘制到目标上下文中的,源图像的矩形选择框的高度。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

为了上传完整的图片,这里dx,dy必须设置为0,dWidth和dheight必须设置为原始图片的宽度和高度。这就是为什么我们需要等image对象下载完毕后获取其原始尺寸,这很关键!neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

3、图片上传neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

function fileUpload() {   
     var data = canvas.toDataURL("image/jpeg", quality);   
     //dataURL 的格式为 “data:image/png;base64,****”,逗号之前都是一些说明性的文字,我们只需要逗号之后的就行了   
    datadata = data.split(',')[1];   
    data = window.atob(data);   
    var ia = new Uint8Array(data.length);   
    for (var i = 0; i < data.length; i  ) {   
          ia[i] = data.charCodeAt(i);   
    };   
     //canvas.toDataURL 返回的默认格式就是 image/png   
    var blob = new Blob([ia], {   
     type: "image/jpeg"   
    });   
    var fd = new FormData();   
        fd.append('myFile', blob);   
    var xhr = new XMLhttpRequest();   
    xhr.addEventListener("load", opts.success, false);   
    xhr.addEventListener("error", opts.error, false);   
    xhr.open("POST", opts.url);   
    xhr.send(fd);   
 }  

这里用的关键方法是canvas.toDataURLneTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

canvas.toDataURL(type, encoderOptions);  

官方的说明是The hTMLCanvasElement.toDataURL() method returns a data URI containing a representation of the image in the format specified by the type parameter (defaults to PNG). The returned image is in a resolution of 96 dpi.实际上就是读取canvas画布上图片的数据。其默认是png格式,如果第一个参数type是image/jpeg的话,第二个参数encoderOptions就可以用来设置图片的压缩质量,经过测试,如果是png格式,100%的宽高经过该方法还有可能使图片变大~~~~适得其反,所以我们可以在canvas.drawImage的时候适当设置sWidth和sheight,比如同比例缩小1.5倍等,图片质量其实并不太影响查看,尤其对尺寸比较大的图片来说。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

上面还有比较陌生的方法atob,其作用是做解码,因为图片格式的base64.neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

var encodedData = window.btoa("hello, world"); // encode a string   
var decodedData = window.atob(encodedData); // decode the string  

该方法解码出来可能是一堆乱码,Uint8Array返回的是8进制整型数组。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

Blob是存储二进制文件的容器,典型的Blob对象是一个图片或者声音文件,其默认是PNG格式。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

var blob = new Blob([ia], {   
     type: "image/jpeg"   
    });  

最后通过ajax将Blob对象发送到server即可。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

整个流程大致如上,但是~~~实现以后测试跑来说:“你不是说图片压缩了吗,为什么图片还是上传那么慢!”,哥拿起手机对妹纸演示了一下,明明很快嘛,于是反道“是你手机不行或者网络不好吧,你下载图片看明明变小了,比之前肯定快,你看我秒传”。呵呵,说归说,还是偷偷检查代码,在浏览器中打时间log,对比没压缩之前的,尼玛!!!居然才快了几百毫秒!!折腾了半天,之前的代码也重构了,玩我呢。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

细心的大神看了上面的代码估计能猜出问题在哪,没错,获取本地图片长宽尺寸的时候出了问题。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

我去,获取本地4M大小的图片尺寸花了3174ms!!,图片越大时间也越久~neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

image.onload = function() {   
        var w = image.naturalWidth,   
          h = image.naturalheight;   
        canvas.width = w / 1.5;   
        canvas.height = h / 1.5;   
        ctx.drawImage(image, 0, 0, w, h, 0, 0, w / 1.5, h / 1.5);   
        Upload.fileUpload(type);   
};  

浏览器在本地取图片的时候是没法直接像file.size一样获取其长宽的,只能通过FileReader拿到内容后赋值给新建的image对象,新建的image对象下载需要时间!怎么破?不就是获取本地图片的尺寸吗,难道没有别的办法了?neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

于是想到了之前研究过的快速获取图片长宽的博文,点击进入 ,demo地址:http://jsbin.com/jivugadure/edit?html,js,output,定时去查询图片加载过程中的高度或者宽度,不用等整个图片加载完毕。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

测了下,还是不行,因为定时查询这种方法对常规的server返回的图片有作用,这里图片地址是base64,貌似时间还更久了~哭。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

小结一下:neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

1、用hTML5来压缩图片上传是可行的,在移动端我们不用依赖客户端或者插件,目前主流浏览器支持程度已经很高了。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

2、压缩图片一方面是想减少用户上传等待的时间,另外也减少用户为此牺牲的流量,从整体时间来看,因为获取图片尺寸导致多一次下载需要耗时,其实压不压缩时间差别并不是特别大。除非大神们找到合适的方法能够直接获取图片的尺寸,麻烦也告知我一声,万分感谢;neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

3、既然时间成本差不多,但是我们压缩了图片,减少了图片的大小,减少了流量的消耗,存储空间以及下次获取该图片的时间,所以还是值得的。neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

网页中照片预览导航设计技巧neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

导航并不只是指常位于网站头部的导航条,路边的指示牌、商场的指示牌等等都是一种导航,可以说导航在生活中无处不在,如果没有这些导航存在,那么我们将迷失,迷失在互联网信息的海洋中,迷失在纵横交错的马路上,迷失在琳琅满目的商品货架之间。  在所谓的WEB2.0风潮疯狂的从国外吹入国内的时候,国外一些成功网站的成功模式也疯狂的吹入到国内的模仿者的眼前。目前在国内关于网络相册方面或者时尚一点是说关于WEB2.0网络相册方面做得比较好的应该算是yupoo了,同时它也是国内模仿flickr模式最像的最成功的——事实上yupoo几乎就是另一个语言版本的flickr。抛除商业运营等其他因素,仅仅来比较一下两者关于照片预览导航系统(不知道正确的叫法,就自己为其命了个名)上的不一样之处,或者是说两者在对用户使用方式的理解上的不一样之处。 neTAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

关于css的相关的知识就说到这里希望能够可以帮助更多的朋友们。,html5,图片压缩,图片上传

分享到:

  admin

注册时间:

网站:0 个   APP:3 个  文章:0 篇

  • 76083

    网站

  • 577

    APP

  • 304416

    文章

  • 56004

    会员

赶快注册账号,推广您的网站吧!
文章分类
热门网站
最新入驻APP小程序

宝贝市场2023-02-08

宝贝市场——买手和卖家商品展示

夺宝助手2023-02-08

夺宝助手小程序,查看每日快夺宝平

查诚信2023-02-08

查诚信是一款免费的商业查询工具

车价天天报2023-02-08

快速连接汽车销售,获知汽车最新报

考勤助理小程序2023-02-08

上班签到考勤,实时定位,后台轻松

汽车报价大全查询2023-02-08

汽车报价大全查询提供最新汽车市