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,超强推荐base.js
Dec 23 Javascript
jquery 圆形旋转图片滚动切换效果
Jan 19 Javascript
IE6/7/8/9不支持exec的简写方式
May 25 Javascript
js批量设置样式的三种方法不推荐使用with
Feb 25 Javascript
通过点击jqgrid表格弹出需要的表格数据
Dec 02 Javascript
几种二级联动案例(jQuery\Array\Ajax php)
Aug 13 Javascript
微信js-sdk界面操作接口用法示例
Oct 12 Javascript
JS中parseInt()和map()用法分析
Dec 16 Javascript
详解vue+vuex+koa2开发环境搭建及示例开发
Jan 22 Javascript
JS/HTML5游戏常用算法之碰撞检测 地图格子算法实例详解
Dec 12 Javascript
浅谈一种让小程序支持JSX语法的新思路
Jun 16 Javascript
在Vue中获取自定义属性方法:data-id的实例
Sep 09 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
利用discuz自带通行证整合dedecms的方法以及文件下载
2007/03/06 PHP
PHP读取数据库并按照中文名称进行排序实现代码
2013/01/29 PHP
PHP图片裁剪函数(保持图像不变形)
2014/05/04 PHP
php实现的mysqldb读写分离操作类示例
2017/02/07 PHP
PHP 结合 Boostrap 结合 js 实现学生列表删除编辑及搜索功能
2019/05/21 PHP
用javascript实现改变TEXTAREA滚动条和按钮的颜色,以及怎样让滚动条变得扁平
2007/04/20 Javascript
Ajax+Json 级联菜单实现代码
2009/10/27 Javascript
JS onkeypress兼容性写法详解
2016/04/27 Javascript
JS中将多个逗号替换为一个逗号的实现代码
2017/06/23 Javascript
ES7中利用Await减少回调嵌套的方法详解
2017/11/01 Javascript
vue-cli3 从搭建到优化的详细步骤
2019/01/20 Javascript
webpack-url-loader 解决项目中图片打包路径问题
2019/02/15 Javascript
解决layer.confirm选择完之后消息框不消失的问题
2019/09/16 Javascript
jquery实现穿梭框功能
2021/01/19 jQuery
[06:16]《DAC最前线》之地区预选赛全面回顾
2015/01/19 DOTA
[51:17]Mski vs VGJ.S Supermajor小组赛C组 BO3 第三场 6.3
2018/06/04 DOTA
Python中为什么要用self探讨
2015/04/14 Python
Python简单实现socket信息发送与监听功能示例
2018/01/03 Python
python线程池threadpool实现篇
2018/04/27 Python
python 爬虫 批量获取代理ip的实例代码
2018/05/22 Python
python3实现带多张图片、附件的邮件发送
2019/08/10 Python
python multiprocessing模块用法及原理介绍
2019/08/20 Python
Python模拟登录和登录跳转的参考示例
2020/10/30 Python
检测用户浏览器是否支持CSS3的方法
2009/08/29 HTML / CSS
CSS3的first-child选择器实战攻略
2016/04/28 HTML / CSS
浅谈HTML5 服务器推送事件(Server-sent Events)
2017/08/01 HTML / CSS
伯克斯奥特莱斯:Burkes Outlet
2019/03/30 全球购物
英国领先的体验日提供商:Buyagift
2019/04/19 全球购物
工程预算与管理应届生求职信
2013/10/06 职场文书
会展中心部门工作职责
2013/11/27 职场文书
小学语文教学反思
2014/02/10 职场文书
《画家乡》教学反思
2014/04/22 职场文书
小学校园广播稿集锦
2014/10/04 职场文书
会议简讯范文
2015/07/20 职场文书
承诺书怎么写 ?
2019/04/16 职场文书
详解JS WebSocket断开原因和心跳机制
2021/05/07 Javascript