您现在的位置是:网站首页> 编程资料编程资料
移动端HTML5实现文件上传HTML5 文件上传下载的实例代码HTML5拖拉上传文件的简单实例HTML5应用之文件上传HTML5+WebSocket实现多文件同时上传的实例移动端HTML5实现文件上传功能【附代码】html5实现多文件的上传示例代码HTML5拖拽文件到浏览器并实现文件上传下载功能代码HTML5 form标签之解放表单验证、增加文件上传、集成拖放的使用方法HTML5 FormData 方法介绍以及实现文件上传示例
2021-08-30
1597人已围观
简介 这篇文章主要介绍了移动端HTML5实现文件上传的相关资料,利用H5轻松实现文件上传操作,感兴趣的小伙伴们可以参考一下
PC端上传文件多半用插件,引入flash都没关系,但是移动端要是还用各种冗余的插件估计得被喷死,项目里面需要做图片上传的功能,既然H5已经有相关的接口且兼容性良好,当然优先考虑用H5来实现。
用的技术主要是:
ajax
FileReader
FormData
HTML结构:
XML/HTML Code复制内容到剪贴板
- <div class="camera-area">
- <form enctype="multipart/form-data" method="post">
- <input type="file" name="fileToUpload" class="fileToUpload" accept="image/*" capture="camera"/>
- <div class="upload-progress"><span>span>div>
- form>
- <div class="thumb">div>
- div>
已经封装好的upload.js,依赖zepto
JavaScript Code复制内容到剪贴板
- (function($) {
- $.extend($.fn, {
- fileUpload: function(opts) {
- this.each(function() {
- var $self = $(this);
- var doms = {
- "fileToUpload": $self.find(".fileToUpload"),
- "thumb": $self.find(".thumb"),
- "progress": $self.find(".upload-progress")
- };
- var funs = {
- //选择文件,获取文件大小,也可以在这里获取文件格式,限制用户上传非要求格式的文件
- "fileSelected": function() {
- var files = (doms.fileToUpload)[0].files;
- var count = files.length;
- for (var index = 0; index < count; index++) {
- var file = files[index];
- var fileSize = 0;
- if (file.size > 1024 * 1024)
- fileSize = (Math.round(file.size * 100 / (1024 * 1024)) / 100).toString() + 'MB';
- else
- fileSize = (Math.round(file.size * 100 / 1024) / 100).toString() + 'KB';
- }
- funs.uploadFile();
- },
- //异步上传文件
- uploadFile: function() {
- var fd = new FormData();//创建表单数据对象
- var files = (doms.fileToUpload)[0].files;
- var count = files.length;
- for (var index = 0; index < count; index++) {
- var file = files[index];
- fd.append(opts.file, file);//将文件添加到表单数据中
- funs.previewImage(file);//上传前预览图片,也可以通过其他方法预览txt
- }
- var xhr = new XMLHttpRequest();
- xhr.upload.addEventListener("progress", funs.uploadProgress, false);//监听上传进度
- xhr.addEventListener("load", funs.uploadComplete, false);
- xhr.addEventListener("error", opts.uploadFailed, false);
- xhr.open("POST", opts.url);
- xhr.send(fd);
- },
- //文件预览
- previewImage: function(file) {
- var gallery = doms.thumb;
- var img = document.createElement("img");
- img.file = file;
- doms.thumb.html(img);
- // 使用FileReader方法显示图片内容
- var reader = new FileReader();
- reader.onload = (function(aImg) {
- return function(e) {
- aImg.src = e.target.result;
- };
- })(img);
- reader.readAsDataURL(file);
- },
- uploadProgress: function(evt) {
- if (evt.lengthComputable) {
- var percentComplete = Math.round(evt.loaded * 100 / evt.total);
- doms.progress.html(percentComplete.toString() + '%');
- }
- },
- "uploadComplete": function(evt) {
- alert(evt.target.responseText)
- }
- };
- doms.fileToUpload.on("change", function() {
- doms.progress.find("span").width("0");
- funs.fileSelected();
- });
- });
- }
- });
- })(Zepto);
调用方法:
JavaScript Code复制内容到剪贴板
- $(".camera-area").fileUpload({
- "url": "savetofile.php",
- "file": "myFile"
- });
PHP部分:
PHP Code复制内容到剪贴板
- if (isset($_FILES['myFile'])) {
- // Example:
- writeLog($_FILES);
- move_uploaded_file($_FILES['myFile']['tmp_name'], "uploads/" . $_FILES['myFile']['name']);
- echo 'successful';
- }
- function writeLog($log){
- if(is_array($log) || is_object($log)){
- $log = json_encode($log);
- }
- $log = $log."\r\n";
- file_put_contents('log.log', $log,FILE_APPEND);
- }
- ?>
以上就是本文的全部内容,希望对大家的学习有所帮助。
原文:http://www.cnblogs.com/hutuzhu/p/5254532.html
相关内容
- 一些HTML代码的编写风格建议小结熟手的html编写风格与原因分析编写灵活、稳定、高质量的HTML和css代码规范指南HTML代码书写规范指南XHTML编码七条基本规范小结规范HTML代码可以节省修改代码的时间学习如何书写整洁规范的HTML标记网页制作中使用规范的HTML代码的几点HTML网页META标签内容写作规范要点HTML5 语义化结构化规范化
- 编写灵活、稳定、高质量的HTML和css代码规范指南CSS代码书写规范究极指南全面总结CSS代码的编写规范及优化建议css代码缩写 div+css布局代码简写规范19楼论坛的前端CSS代码规范介绍让样式表CSS代码更加专业规范闭合浮动元素让CSS代码更规范-CSS教程-网页制作-网页教学网分享20条编写 CSS 代码的建议
- HTML的checkbox和radio样式美化的简单实例HTML5实现的自定义Checkbox和Radiobox 很酷的选中动画效果源码通过jQuery实现自定义可以替代html自带的checkbox和radiobox
- 详解HTML/XHTML中img图像标签的基本用法HTML中img标签只显示图片中心位置的方法(三种方法)HTMLimg标签的alt属性和title属性使用介绍HTML图片img标签_动力节点Java学院整理
- HTML基础知识——css样式表,样式属性,格式与布局详解网页布局中CSS样式无效的十个重要原因详解CSS样式表与格式布局详解DIV+CSS通用样式布局实例代码CSS布局中如何组织样式表以便于简化、维护详解常用css样式(布局)
- PHP-HTMLhtml重要知识点笔记(必看)HTML5中的nav标签学习笔记HTML学习笔记--HTML的语法详解(必看)HTML5学习笔记之html5与传统html区别 HTML设计模式日常学习笔记整理HTML基础笔记(推荐)
- HTML基础知识——设置超链接的样式简单实例html/css基础篇——html代码编写过程中的几个警惕点(必看)html、css基础注意点(前端必看篇)HTML CSS样式基础(必看篇)HTML基础总结推荐(段落)HTML基础知识——css样式表,样式属性,格式与布局详解HTML基础必看——全面了解css样式表HTML基础必看---表单,图片热点,网页划区和拼接详解HTML基础重点_一般标签、常用标签和表格浅谈HTML(css基础样式)前端开发每天必学之HTML入门介绍
- HTML基础必看——全面了解css样式表html/css基础篇——html代码编写过程中的几个警惕点(必看)html、css基础注意点(前端必看篇)HTML CSS样式基础(必看篇)HTML基础总结推荐(段落)HTML基础知识——css样式表,样式属性,格式与布局详解HTML基础知识——设置超链接的样式简单实例HTML基础必看---表单,图片热点,网页划区和拼接详解HTML基础重点_一般标签、常用标签和表格浅谈HTML(css基础样式)前端开发每天必学之HTML入门介绍
- 如何实现textarea中获取动态剩余字数的方法用CSS实现textArea中的placeholder换行功能使用CSS禁止textarea调整大小功能的方法textarea布局时文字在左下边且不能改变大小尺寸的解决方法HTML中的文本框textarea标签
- 关于table表格中的内容溢出布局方法关于表格table嵌套,边框合并问题的解决方法CSS display属性的table表格布局深入解析HTML的table表格标签与相关的换行问题
