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 相关文章推荐
解析js中获得父窗口链接getParent方法以及各种打开窗口的方法
Jun 19 Javascript
HTML Color Picker(js拾色器效果)
Aug 27 Javascript
node.js中的http.request方法使用说明
Dec 14 Javascript
js+div实现文字滚动和图片切换效果代码
Aug 27 Javascript
javascript中new关键字详解
Dec 14 Javascript
浅谈jquery设置和获得checkbox选中的问题
Aug 19 Javascript
JavaScript中数组slice和splice的对比小结
Sep 22 Javascript
Angualrjs 表单验证的两种方式(失去焦点验证和点击提交验证)
May 09 Javascript
详解如何优雅地在React项目中使用Redux
Dec 28 Javascript
对vux点击事件的优化详解
Aug 28 Javascript
webpack优化的深入理解
Dec 10 Javascript
JavaScript前端实现压缩图片功能
Mar 06 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 Ajax乱码
2008/04/09 PHP
PHP5 面向对象(学习记录)
2009/12/02 PHP
php查看请求头信息获取远程图片大小的方法分享
2013/12/25 PHP
PHP生成指定随机字符串的简单实现方法
2015/04/01 PHP
prototype Element学习笔记(篇一)
2008/10/26 Javascript
JS中图片缓冲loading技术的实例代码
2013/08/29 Javascript
一个小例子解释如何来阻止Jquery事件冒泡
2014/07/17 Javascript
node.js中的http.createServer方法使用说明
2014/12/14 Javascript
js实现鼠标滑过文字链接色彩变化的效果
2015/05/06 Javascript
一起学写js Calender日历控件
2016/04/14 Javascript
bootstrap table实例详解
2017/01/06 Javascript
JavaScript轮播图简单制作方法
2017/02/20 Javascript
80%应聘者都不及格的JS面试题
2017/03/21 Javascript
vue-cli+webpack在生成的项目中使用bootstrap实例代码
2017/05/26 Javascript
Vue应用部署到服务器的正确方式
2017/07/15 Javascript
vue 之 .sync 修饰符示例详解
2018/04/21 Javascript
使用js实现将后台传入的json数据放在前台显示
2018/08/06 Javascript
javascript实现留言板功能
2020/02/08 Javascript
uin-app+mockjs实现本地数据模拟
2020/08/26 Javascript
[38:21]2018DOTA2亚洲邀请赛3月30日 小组赛A组 LGD VS Newbee
2018/03/31 DOTA
python 不以科学计数法输出的方法
2018/07/16 Python
python多行字符串拼接使用小括号的方法
2020/03/19 Python
基于OpenCV python3实现证件照换背景的方法
2019/03/22 Python
Python实现通过解析域名获取ip地址的方法分析
2019/05/17 Python
基于python3 pyQt5 QtDesignner实现窗口化猜数字游戏功能
2019/07/15 Python
任意一块网页内容实现“活”的背景(目前火狐浏览器专有)
2014/05/07 HTML / CSS
html5开发三八女王节表白神器
2018/03/07 HTML / CSS
家得宝墨西哥官网:The Home Depot墨西哥
2019/11/18 全球购物
巴西购物网站:Submarino
2020/01/19 全球购物
文职个人求职信范文
2013/09/23 职场文书
高二美术教学反思
2014/01/14 职场文书
2014年高中班主任工作总结
2014/11/08 职场文书
英文版辞职信
2015/02/28 职场文书
防暑降温通知书
2015/04/27 职场文书
《蜜蜂引路》教学反思
2016/02/22 职场文书
解决Mysql中的innoDB幻读问题
2022/04/29 MySQL