PHP+jQuery+Ajax实现多图片上传效果


Posted in Javascript onMarch 14, 2015

今天我给大家分享的是在不刷新页面的前提下,使用PHP+jQuery+Ajax实现多图片上传的效果。用户只需要点击选择要上传的图片,然后图片自动上传到服务器上并展示在页面上。

PHP+jQuery+Ajax实现多图片上传效果

HTML

我们在页面上放置一个form表单,使用post提交到后台php处理程序upload.php,注意enctype属性设置要支持文件上传。#preview用来显示上传完毕后的图片。关于css样式设置本文不加说明,请参照下载包的源码。

<form id="imageform" method="post" enctype="multipart/form-data" action="upload.php"> 

    <div id="up_status" style="display:none"><img src="loader.gif" alt="uploading"/></div> 

    <div id="up_btn" class="btn"> 

        <span>添加图片</span> 

        <input id="photoimg" type="file" name="photoimg"> 

    </div> 

</form> 

<p>最大100KB,支持jpg,gif,png格式。</p> 

<div id="preview"></div>

jQuery
本实例基于jQuery,因此必须在页面中载入jquery库以及jquery.wallform.js。

<script type="text/javascript" src="jquery.min.js"></script> 

<script type="text/javascript" src="jquery.wallform.js"></script>

当点击按钮“添加图片”后,弹出选择文件对话框,选择要上传的图片后,触发change事件。然后表单#imageform调用jquery.wallform.js的ajaxForm()方法,将表单数据提交给后台PHP处理,并根据返回结果处理页面元素的展示。如果上传成功,图片会一张张排列显示在页面上。关于ajaxForm()的使用可以参照本站文章:Ajax表单提交插件jqery form。

$(function(){ 

    $('#photoimg').die('click').live('change', function(){ 

        var status = $("#up_status"); 

        var btn = $("#up_btn"); 

        $("#imageform").ajaxForm({ 

            target: '#preview',  

            beforeSubmit:function(){ 

                status.show(); 

                btn.hide(); 

            },  

            success:function(){ 

                status.hide(); 

                btn.show(); 

            },  

            error:function(){ 

                status.hide(); 

                btn.show(); 

        } }).submit(); 

    }); 

});

PHP

upload.php处理图片上传,并将上传好的图片保存在uploads/目录,注意该目录要有写权限。首先需要检测是否为POST方式提交,然后判断图片格式、图片大小是否符合要求,然后使用move_uploaded_file()上传图片,并将图片重命名,格式为:time().rand(100,999)。

$path = "uploads/"; 

$extArr = array("jpg", "png", "gif"); 

if(isset($_POST) and $_SERVER['REQUEST_METHOD'] == "POST"){ 

    $name = $_FILES['photoimg']['name']; 

    $size = $_FILES['photoimg']['size']; 

    if(empty($name)){ 

        echo '请选择要上传的图片'; 

        exit; 

    } 

    $ext = extend($name); 

    if(!in_array($ext,$extArr)){ 

        echo '图片格式错误!'; 

        exit; 

    } 

    if($size>(100*1024)){ 

        echo '图片大小不能超过100KB'; 

        exit; 

    } 

    $image_name = time().rand(100,999).".".$ext; 

    $tmp = $_FILES['photoimg']['tmp_name']; 

    if(move_uploaded_file($tmp, $path.$image_name)){ 

        echo '<img src="'.$path.$image_name.'"  class="preview">'; 

    }else{ 

        echo '上传出错了!'; 

    } 

    exit; 

} 

//获取文件类型后缀 

function extend($file_name){ 

    $extend = pathinfo($file_name); 

    $extend = strtolower($extend["extension"]); 

    return $extend; 

}

当然,实际应用中,可以与数据库以及用户中心结合,将用户上传的图片保存在数据表中,具体应用大家可以自行研究。

以上就是本文给大家分享的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
JQUBar 基于JQUERY的柱状图插件
Nov 23 Javascript
js/jQuery简单实现选项卡功能
Jan 02 Javascript
JS中使用sort结合localeCompare实现中文排序实例
Jul 23 Javascript
理解javascript中的原型和原型链
Jul 30 Javascript
jquery实现上传文件大小类型的验证例子(推荐)
Jun 25 Javascript
Google 地图事件实例讲解
Aug 06 Javascript
Angularjs中ng-repeat-start与ng-repeat-end的用法实例介绍
Dec 31 Javascript
使用vue.js编写蓝色拼图小游戏
Mar 17 Javascript
vue.js父组件使用外部对象的方法示例
Apr 25 Javascript
浅谈Vue.nextTick 的实现方法
Oct 25 Javascript
vue里input根据value改变背景色的实例
Sep 29 Javascript
vue实现的双向数据绑定操作示例
Dec 04 Javascript
jQuery oLoader实现的加载图片和页面效果
Mar 14 #Javascript
jQuery实现购物车数字加减效果
Mar 14 #Javascript
jQuery+PHP实现动态数字展示特效
Mar 14 #Javascript
jQuery+slidereveal实现的面板滑动侧边展出效果
Mar 14 #Javascript
jQuery+jRange实现滑动选取数值范围特效
Mar 14 #Javascript
jQuery实现加入购物车飞入动画效果
Mar 14 #Javascript
jQuery插件实现大图全屏图片相册
Mar 14 #Javascript
You might like
基于php常用正则表达式的整理汇总
2013/06/08 PHP
PHP获取一个字符串中间一部分字符的方法
2014/08/19 PHP
YII Framework框架教程之缓存用法详解
2016/03/14 PHP
PHP内部实现打乱字符串顺序函数str_shuffle的方法
2019/02/14 PHP
贴一个在Mozilla中常用的Javascript代码
2007/01/09 Javascript
javascript 动态加载 css 方法总结
2009/07/11 Javascript
JavaScript 学习笔记(十二) dom
2010/01/21 Javascript
js中onload与onunload的使用示例
2013/08/25 Javascript
js校验表单后提交表单的三种方法总结
2014/02/28 Javascript
javascript数组操作总结和属性、方法介绍
2014/04/05 Javascript
JavaScript File API实现文件上传预览
2016/02/02 Javascript
DOM操作原生js 的bug,使用jQuery 可以消除的解决方法
2016/09/04 Javascript
在 Angular 中实现搜索关键字高亮示例
2017/03/21 Javascript
基于JavaScript实现表格滚动分页
2017/11/22 Javascript
使用ajax的post同步执行(实现方法)
2017/12/21 Javascript
NodeJS父进程与子进程资源共享原理与实现方法
2018/03/16 NodeJs
浅谈js获取ModelAndView值的问题
2018/03/28 Javascript
分享5个好用的javascript文件上传插件
2018/09/16 Javascript
Node.js爬虫如何获取天气和每日问候详解
2019/08/26 Javascript
vue项目中js-cookie的使用存储token操作
2020/11/13 Javascript
[01:14]2014DOTA2展望TI 剑指西雅图newbee战队专访
2014/06/30 DOTA
Python实现简单的文本相似度分析操作详解
2018/06/16 Python
python3 kmp 字符串匹配的方法
2018/07/07 Python
python实现推箱子游戏
2020/03/25 Python
Python多线程应用于自动化测试操作示例
2018/12/06 Python
Python中常用的内置方法
2019/01/28 Python
jupyter notebook 实现matplotlib图动态刷新
2020/04/22 Python
html svg生成环形进度条的实现方法
2019/09/23 HTML / CSS
FOREO斐珞尔官方旗舰店:LUNA露娜洁面仪
2018/03/11 全球购物
俄语地区最大的中国商品在线购物网站之一:Umka Mall
2019/11/03 全球购物
限量版运动鞋和街头服饰:TheDrop
2020/09/06 全球购物
商场中秋节活动方案
2014/02/07 职场文书
人力资源管理毕业求职信
2014/08/05 职场文书
财务会计实训报告
2014/11/05 职场文书
护士个人年度总结范文
2015/02/13 职场文书
院系推荐意见
2015/06/05 职场文书