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的闭包的一个示例说明
Nov 18 Javascript
jQuery div层的放大与缩小简单实现代码
Mar 28 Javascript
jQuery动态修改超链接地址的方法
Feb 13 Javascript
AngularJS学习笔记之ng-options指令
Jun 16 Javascript
简单讲解jQuery中的子元素过滤选择器
Apr 18 Javascript
JavaScript——DOM操作——Window.document对象详解
Jul 14 Javascript
Vue AST源码解析第一篇
Jul 19 Javascript
vue解决跨域路由冲突问题思路解析
Nov 03 Javascript
详解如何优雅地在React项目中使用Redux
Dec 28 Javascript
Node解决简单重复问题系列之Excel内容的获取
Jan 02 Javascript
js实现随机点名器精简版
Jun 29 Javascript
Openlayers显示地理位置坐标的方法
Sep 28 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
一些操作和快捷键的理解和讨论
2020/03/04 星际争霸
探讨方法的重写(覆载)详解
2013/06/08 PHP
网页上facebook分享功能具体实现
2014/01/26 PHP
在win7中搭建Linux+PHP 开发环境
2014/10/08 PHP
php限制文件下载速度的代码
2015/10/20 PHP
变量在 PHP7 内部的实现(二)
2015/12/21 PHP
javascript不同页面传值的改进版
2008/09/30 Javascript
jquery 获取json数据实现代码
2009/04/27 Javascript
Kibo 用于处理键盘事件的Javascript工具库
2011/10/28 Javascript
javascript搜索框效果实现方法
2015/05/14 Javascript
AngularJS的依赖注入实例分析(使用module和injector)
2017/01/19 Javascript
JQuery页面随滚动条动态加载效果的简单实现(推荐)
2017/02/08 Javascript
JavaScript中Promise的使用详解
2017/02/26 Javascript
BootStrap下的弹出框加载select2框架失败的解决方法
2017/08/31 Javascript
封装运动框架实战左右与上下滑动的焦点轮播图(实例)
2017/10/17 Javascript
js实现数组内数据的上移和下移的实例
2017/11/14 Javascript
Vue 解决多级动态面包屑导航的问题
2019/11/04 Javascript
Python实现在Linux系统下更改当前进程运行用户
2015/02/04 Python
Python通过select实现异步IO的方法
2015/06/04 Python
Python字符串匹配算法KMP实例
2015/07/18 Python
用tensorflow搭建CNN的方法
2018/03/05 Python
selenium+python实现自动登录脚本
2018/04/22 Python
Python函数装饰器实现方法详解
2018/12/22 Python
将Pytorch模型从CPU转换成GPU的实现方法
2019/08/19 Python
Python实现非正太分布的异常值检测方式
2019/12/09 Python
Django使用Celery加redis执行异步任务的实例内容
2020/02/20 Python
python如何提升爬虫效率
2020/09/27 Python
Pycharm如何自动生成头文件注释
2020/11/14 Python
详解pycharm自动import所需的库的操作方法
2020/11/30 Python
如果NULL定义成#define NULL((char *)0)难道不就可以向函数传入不加转换的NULL了吗
2012/02/15 面试题
关于孝道的演讲稿
2014/05/21 职场文书
2015年党员创先争优承诺书
2015/01/22 职场文书
汽车车尾标语大全
2015/08/11 职场文书
Axios取消重复请求的方法实例详解
2021/06/15 Javascript
python基础之类属性和实例属性
2021/10/24 Python
从结婚开始的恋爱故事。小说《我的美好婚事》TV动画化决定
2022/04/07 日漫