本文为原创,转载请注明出处: cnzt  文章:cnzt-p

http://www.cnblogs.com/zt-blog/p/6709037.html 

一. 思路:

 <input type="file" accept="image/*" id="imgUpload" />

二. 原始效果:

 该标签在页面的原始效果如下(选择文件按钮),PC端点击会出现图片选择对话框。这里没有添加任何css代码,很丑。没关系,我们的案例中会做个漂亮一点点的~

  PC chrome(其他效果差不多):

  

  iOS safari:

  

  Android:

  并没有。。。。。。安卓手机

三. 兼容性:

 PC browsers -- 选择本地图片

 iOS -- 可以从图库选择或者拍照

 Android -- 可以选择图库或者文件管理。一句话,安卓之大,无奇不有,各种文件目录啊。。。

 补充20170421:安卓的拍照功能可以通过app端改变接口实现。

四. 用法:

  document.getElementById("imgUpload").onchange = function(e){
   console.log(e);
   var file = e.target.files[0];    console.log(file );
 }

 onchange -- input内容改变是触发,即重新选择新的文件。

 e -- onchange事件的参数,指向change事件,这里我们使用它的target属性。结构如下:

  

 file -- e.target.files[0] -- input标签中的文件对象,包含文件的修改时间,尺寸,类型及文件名,结构如下:

  

五. 上传图片:

 上传图片利用formdata,通过new Formdata(formdom)来获取formdata,结合ajax上传server

 //html代码
<form action="" id="formId">
<input type="file" name="image" accept="images/*" id="CameraUplBtn" capture="camera" />
</form> //js代码
var data = new FormData(document.getElementById("formId"));
$.ajax({
url: url_send,
headers: url_headers,
data: data,
type: "post",
contentType: false,
processData: false,
success: function(data){
//
},
error: function(data){
//
}
});

 注意:contentType: false, processData: false -- 这两个参数规定发送数据不用编码,禁止将data装换为请求字符串格式。

六. 案例(仿微信对话框的图片发送):

  1. 先上效果图,包括图片发送成功和失败的效果:

  

  2. 实现:

  2.1 页面布局

  前面说过了,file input默认样式很丑的,如何做成我们效果图上的样子呢,方法很多,我这里是将input设置宽高和透明度,以及将它定位到“图片”和“相机”的上层,超级简单无bug。

  2.2 事件绑定

  绑定onchange,该拿e拿e,该拿file拿file,见 第四点。

  2.3 图片添加到对话框

  我们采用data url的方式添加要发送的图片。怎么将img图片转成data url形式呢,方法也很多,我们用FileReader。上代码:

  

 var reader = new FileReader();
var imgDom;
var dataUrl;
reader.onload = function(e) {
imgItem = document.createElement('img');
dataUrl= e.target.result; //Android fix
if(isAndroid() && dataUrl.indexOf("data:image/") != 0){
dataUrl= dataUrl.replace("base64,", "image/" + file.type.split("/").pop()+ ";base64,");
} $(imgDom).attr('src',dataUrl); //拼接dom
var appendHTML = '<li class="me">'+
'<div class="c2"><span class="arrow"></span><span class="dialogText">'+
'<i data-id="'+file.name+'" class="uploading fa fa-spin fa-spinner"></i></span></div><div class="c1"></div></li>';
$("#dialogs").append(appendHTML);
imgItem.insertBefore($("i[data-id='"+file.name+"']")); //图片加载完后刷新iscroll
refreshScroll();
};
reader.readAsDataURL(file);

  创建一个FileReader对象,readAsDataURL()以data url方式读取文件,onload事件的参数load事件对象event.target.result即为文件的data url形式。然后在对话列表中增加一行,data url地址赋值给img的src,为了效果好一点,在图片旁边加上loading的圈圈,等图片上上传完成后去掉即可。

  这里对安卓的处理是参考百度反馈页面的fix,抱拳谢过~

  2.4 上传图片大server -- 见 第五点。

  2.5 错误处理

  如果图片上传失败,则在图片旁边添加小圆叹号图标,并给其绑定一个click/tap事件,点击重新上传图片。

本文完!

html页面中拍照和上传照片那些事儿(一)的更多相关文章

  1. html页面中拍照和上传照片那些事儿(二)

    本文为原创,转载请注明出处: cnzt       文章:cnzt-p http://www.cnblogs.com/zt-blog/p/6895352.html 本文主要说下iOS上传的照片在安卓机 ...

  2. 通过链接将JSP页面中一变量传到另一JSP界面中

    A.jsp 发送 <a herf="B.jsp?name=<%=name%>">传递到B页面</a> B.jsp  接收 <%String ...

  3. phonegap 拍照上传照片

    js代码 可以完全从  phonegap 官网扣下来 使用的是2.3版本的phonegap<script type="text/javascript" src="c ...

  4. 获取页面中更新删除传过来的id

    利用uri辅助函数 $id=$this->uri->segment(4); 其中segment(参数)  是表示你要截取获得第几个数据.

  5. 李洪强iOS开发之上传照片时英文改中文

    今天在做项目的时候,有一个功能是上传照片选择系统相册的照片,或者拍照上传照片,但是页面上的文字是英文的, 需求想改成中文的,解决方法是在 info.plist里面添加 Localized resour ...

  6. webuploader的一个页面多个上传按钮实例

    借鉴一位大佬的demo  附上他的github地址https://github.com/lishuqi 我把他的cxuploader.js改了不需要预览  直接上传图片后拿到回传地址给img标签显示图 ...

  7. 基于jQuery的ajax系列之用FormData实现页面无刷新上传

    接着上一篇ajax系列之用jQuery的ajax方法向服务器发出get和post请求写,这篇主要写如何利用ajax和FormData实现页面无刷新的文件上传效果,主要用到了jQuery的ajax()方 ...

  8. 用Seam实现:图片上传 + 保存到数据库 + 从数据库读出图片并显示到页面中

    上传图片并保存到数据库 seam给我们提供了 s:fileUpload 标签以完成文件上传功能.使用该标签时,要在web.xml中声明一个Seam的过滤器: <filter> <fi ...

  9. 使用PLupload在同一页面中进行多个不同类型上传解决方案和一次多文件上传的注意事项

    首先感谢,http://www.cnblogs.com/2050/p/3913184.html 这篇文章作者. 在使用PLUpload之前个人先封装了一些常用配置,并且将success与error做为 ...

随机推荐

  1. 2015 AlBaath Collegiate Programming Contest(2月14日训练赛)

    A (By ggg): 题意:一个人还有x秒到红绿灯,这个红绿灯有g秒绿灯,y秒黄 灯,r秒红灯,问你到红绿灯的时候是什么灯.值得注意的是绿 灯变黄灯时,第g秒是黄灯了. B (By Anxdada) ...

  2. Qt 之 QApplication

    1.QApplication QApplication类管理GUI程序的控制流和主要设置,是基于QWidget的,为此特化了QGuiApplication的一些功能,处理QWidget特有的初始化和结 ...

  3. windows文件备份到linux:windows定时任务+cwrsync+ssh免密码认证

    一.安装cwrsync 二.创建密钥对,实现ssh免密码验证 linux服务器上 [root@zabbix ~]# ssh-keygen Generating public/private rsa k ...

  4. solr中的Tokenizer Filter

    Tokenizer Tokenizer 的工作是将文本流分解为令牌,其中每个令牌(通常)是文本中字符的子序列.分析器知道它配置的字段,但 tokenizer 不是.Tokenizers 从字符流(Re ...

  5. LeetCode(81) Search in Rotated Array II

    题目 Follow up for "Search in Rotated Sorted Array": What if duplicates are allowed? Would t ...

  6. 刁肥宅详解中缀表达式求值问题:C++实现顺序/链栈解决

    1. 表达式的种类 如何将表达式翻译成能够正确求值的指令序列,是语言处理程序要解决的基本问题,作为栈的应用事例,下面介绍表达式的求值过程. 任何一个表达式都是由操作数(亦称运算对象).操作符(亦称运算 ...

  7. Android学习2013年10月11日

    1.LinearLayout http://www.cnblogs.com/salam/archive/2010/10/20/1856793.html LinearLayout是线性布局控件,它包含的 ...

  8. [luoguP1227] [JSOI2008]完美的对称(sort)

    传送门 排序! #include <cstdio> #include <iostream> #include <algorithm> #define N 20001 ...

  9. BZOJ 3721: PA2014 Final Bazarek【乱搞】

    有n件商品,选出其中的k个,要求它们的总价为奇数,求最大可能的总价. Input 第一行一个整数n(1<=n<=1000000),表示商品数量.接下来一行有n个整数,表示每件商品的价格,范 ...

  10. 【三分+精度问题】G. Toxophily

    https://www.bnuoj.com/v3/contest_show.php?cid=9154#problem/G [题意] 已知人的坐标在(0,0),靶的位置在(x,y),人以速度v射箭并且射 ...