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 相关文章推荐
JavaScript效率调优经验
Jun 04 Javascript
用js正确判断用户名cookie是否存在的方法
Jan 28 Javascript
js实现鼠标悬浮给图片加边框的方法
Jan 30 Javascript
jQuery插件Zclip实现完美兼容个浏览器点击复制内容到剪贴板
Apr 30 Javascript
javascript结合canvas实现图片旋转效果
May 03 Javascript
轻松实现javascript图片轮播特效
Jan 13 Javascript
angularjs实现上拉加载和下拉刷新数据功能
Jun 12 Javascript
微信小程序switch组件使用详解
Jan 31 Javascript
详解Vue.directive 自定义指令
Mar 27 Javascript
微信小程序实现点击图片放大预览
Oct 21 Javascript
基于Vue el-autocomplete 实现类似百度搜索框功能
Oct 25 Javascript
vue3如何优雅的实现移动端登录注册模块
Mar 29 Vue.js
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学习之输出字符串(echo,print,printf,print_r和var_dump)
2011/04/17 PHP
PHP第一季视频教程(李炎恢+php100 不断更新)
2011/05/29 PHP
php批量删除数据库下指定前缀的表以prefix_为例
2014/08/24 PHP
ecshop后台编辑器替换成ueditor编辑器
2015/03/03 PHP
调用WordPress函数统计文章访问量及PHP原生计数器的实现
2016/03/21 PHP
Nginx下ThinkPHP5的配置方法详解
2017/08/01 PHP
PHP使用星号替代用户名手机和邮箱的实现代码
2018/02/07 PHP
JQuery获取元素文档大小、偏移和位置和滚动条位置的方法集合
2010/01/12 Javascript
腾讯与新浪的通过IP地址获取当前地理位置(省份)的接口
2010/07/26 Javascript
基于jQuery的360图片展示实现代码
2012/06/14 Javascript
JavaScript面向对象编程入门教程
2014/04/16 Javascript
js处理表格对table进行修饰
2014/05/26 Javascript
JavaScript输出当前时间Unix时间戳的方法
2015/04/06 Javascript
JQuery实现可直接编辑的表格
2015/04/16 Javascript
简单易懂的天气插件(代码分享)
2017/02/04 Javascript
Angular在一个页面中使用两个ng-app的方法(二)
2017/02/20 Javascript
vue 设置proxyTable参数进行代理跨域
2018/04/09 Javascript
微信小程序自定义多选事件的实现代码
2018/05/17 Javascript
基于Vue的商品主图放大镜方案详解
2019/09/19 Javascript
解决Echarts2竖直datazoom滑动后显示数据不全的问题
2020/07/20 Javascript
[03:58]兄弟们,回来开黑了!DOTA2昔日战友招募宣传视频
2016/07/17 DOTA
Python中input和raw_input的一点区别
2014/10/21 Python
python一键升级所有pip package的方法
2017/01/16 Python
python常见排序算法基础教程
2017/04/13 Python
深入浅析python 中的匿名函数
2018/05/21 Python
解决pandas使用read_csv()读取文件遇到的问题
2018/06/15 Python
flask框架使用orm连接数据库的方法示例
2018/07/16 Python
python实现简单的单变量线性回归方法
2018/11/08 Python
python解析xml简单示例
2019/06/21 Python
python多线程实现代码(模拟银行服务操作流程)
2020/01/13 Python
python判断变量是否为int、字符串、列表、元组、字典的方法详解
2020/02/13 Python
股票投资建议书
2014/05/19 职场文书
2015年小学英语教师工作总结
2015/05/12 职场文书
答谢酒会主持词
2015/07/02 职场文书
2019年朋友圈经典励志语录50条
2019/07/05 职场文书
Spring Boot优化后启动速度快到飞起技巧示例
2022/07/23 Java/Android