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 相关文章推荐
Jquery 表单取值赋值的一些基本操作
Oct 11 Javascript
用JS判别浏览器种类以及IE版本的几种方法小结
Aug 02 Javascript
js中的事件捕捉模型与冒泡模型实例分析
Jan 10 Javascript
JavaScript setTimeout使用闭包功能实现定时打印数值
Dec 18 Javascript
Bootstrap每天必学之滚动监听
Mar 16 Javascript
JavaScript 对象字面量讲解
Jun 06 Javascript
基于jquery实现多选下拉列表
Aug 02 jQuery
BootStrap模态框和select2合用时input无法获取焦点的解决方法
Sep 01 Javascript
JavaScript实现的简单加密解密操作示例
Jun 01 Javascript
简单了解JavaScript异步
May 23 Javascript
layui实现数据表格自定义数据项
Oct 26 Javascript
Vue中使用JsonView来展示Json树的实例代码
Nov 16 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
ip签名探针
2006/10/09 PHP
PHP Document 代码注释规范
2009/04/13 PHP
深入PHP与浏览器缓存的分析
2013/06/03 PHP
PHP计算2点经纬度之间的距离代码
2013/08/12 PHP
php画图实例
2014/11/05 PHP
php上传文件并显示上传进度的方法
2015/03/24 PHP
PHP YII框架开发小技巧之模型(models)中rules自定义验证规则
2015/11/16 PHP
PHP远程连接oracle数据库操作实现方法图文详解
2019/04/11 PHP
Array对象方法参考
2006/10/03 Javascript
Stop SQL Server
2007/06/21 Javascript
javascript 浏览器判断 绑定事件 arguments 转换数组 数组遍历
2009/07/06 Javascript
jsTree 基于JQuery的排序节点 Bug
2011/07/26 Javascript
js中replace的用法总结
2013/12/27 Javascript
在Node.js应用中使用Redis的方法简介
2015/06/24 Javascript
easyui Draggable组件实现拖动效果
2015/08/19 Javascript
JavaScript判断手机号运营商是移动、联通、电信还是其他(代码简单)
2015/09/25 Javascript
浅析Node.js 中 Stream API 的使用
2015/10/23 Javascript
微信小程序 setData的使用方法详解
2017/04/20 Javascript
集合Bootstrap自定义confirm提示效果
2017/09/19 Javascript
js实现简单分页导航栏效果
2019/06/28 Javascript
详解Python中的join()函数的用法
2015/04/07 Python
Python实现霍夫圆和椭圆变换代码详解
2018/01/12 Python
python批量导入数据进Elasticsearch的实例
2018/05/30 Python
基于python实现文件加密功能
2020/01/06 Python
Python实现异步IO的示例
2020/11/05 Python
英国天然宝石首饰购买网站:Gemondo Jewellery
2018/10/23 全球购物
Tea Collection官网:一家位于旧金山的童装公司
2020/08/07 全球购物
世界经理人咨询有限公司面试
2014/09/23 面试题
高级工程师岗位职责
2013/12/15 职场文书
syb养殖创业计划书
2014/01/09 职场文书
公司离职证明范本
2014/01/13 职场文书
电子商务专业应届生求职信
2014/05/28 职场文书
文明工地标语
2014/06/16 职场文书
公司员工活动策划方案
2014/08/20 职场文书
2014年客房部工作总结
2014/11/22 职场文书
Django debug为True时,css加载失败的解决方案
2021/04/24 Python