本文摘自PHP中文网,作者不言,侵删。
这篇文章主要介绍了HTML5实现简单图片上传所遇到的问题及解决办法 的相关资料,需要的朋友可以参考下 一、展示
因为前端上传文件是必须通过form表单的,不能使用ajax,这样的话一个移动页面放入一个type为file的input真心不怎么好看,如下图,很挫有没有

解决办法找了下,PC上有些是把这个input换成flash,采用jquery的工具库比如uploadify来做,但是移动端大部分浏览器是不支持flash的。所以最后采用的办法还是用form表单的形式,只是把这个form和input的透明度设置为0,让它们和准备显示的内容同时在一个p中,显示的内容可以做成自己想要的样子。代码如下:
复制代码
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | <!DOCTYPE html>
< html >
< head >
< meta charset = "UTF-8" >
< meta name = "viewport" content = "width=device-width,initial-scale=1.0,user-scalable=no" >
< title ></ title >
< style >
p{width: 100%;}
.logo img{display:block; margin:0 auto;}
.upload{position: relative;width: 80px;height: 18px;line-height: 18px;background: #2fc7c9;text-align: center;
color: #FFF;padding: 0px 5px;-webkit-border-radius: 2px;border-radius: 2px;
margin: 0 auto;
}
.upload form{width:100%;position:absolute; left:0; top:0;opacity:0; filter:alpha(opacity=0);}
.upload form input{width: 100%;}
</ style >
</ head >
< body >
< p class = "logo" >
< img src = "img/1.jpg" />
</ p >
< p class = "upload" >
< p >上传图片</ p >
< form >
< input type = "file" />
</ form >
</ p >
</ body >
</ html >
|

样子如上图,这样展现就在“上传图片”这个p标签中,点击它就有选择file的效果
二、JS代码
我这边写的蛮简单的,只是用了下h5上传的的基本功能
html代码如下,action为要请求的路径,我这边做的是当文件发生改变时就上传修改头像,input标签的name属性不能省去,具体跟后端接口有关
复制代码
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | < form id = "uploadForm" enctype = "multipart/form-data" method = "post" action = "XXXXXX" >
< input type = "file" name = "imageFile" id = "imageFile" onchange = "fileSelected()" />
</ form >
var iMaxFilesize = 2097152; //2M
window.fileSelected = function() {
var oFile = document.getElementById('imageFile').files[0]; //读取文件
var rFilter = /^(image\/bmp|image\/gif|image\/jpeg|image\/png|image\/tiff)$/i;
if (!rFilter.test(oFile.type)) {
alert("文件格式必须为图片");
return;
}
if (oFile.size > iMaxFilesize) {
alert("图片大小不能超过2M");
return;
}
var vFD = new FormData(document.getElementById('uploadForm')), //建立请求和数据
oXHR = new XMLHttpRequest();
oXHR.addEventListener('load', function(resUpload) {
//成功
}, false);
oXHR.addEventListener('error', function() {
//失败
}, false);
oXHR.addEventListener('abort', function() {
//上传中断
}, false);
oXHR.open('POST', actionUrl);
oXHR.send(vFD);
};
|
以上内容给大家分享了HTML5实现简单图片上传所遇到的问题及解决办法的相关知识,希望对大家有所帮助。
相关推荐:
Html5实现二维码扫描并解析
HTML5实现分享到微信好友朋友圈QQ好友QQ空间微博二维码功能
以上就是HTML5实现简单图片上传所遇到的问题及解决办法 的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
如何选择web前端模板引擎(推荐)
总结HTML5中的标签
什么是HTML5技术
HTML5的集合
h5应用缓存-manifest的具体介绍
详细介绍HTML5新标签的兼容性处理(图)
如何自动获取HTML5的data-*属性示例代码详解
HTML5视频音频实现步骤
HTML5新增了哪些标签和属性?新增了标签和属性(总结)
HTML5 移动端自适应布局
更多相关阅读请进入《HTML5》频道 >>
人民邮电出版社
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者
转载请注明出处:木庄网络博客 » HTML5实现简单图片上传所遇到的问题及解决办法