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中toString()方法的使用详解
Jun 05 Javascript
JavaScript编写点击查看大图的页面半透明遮罩层效果实例
May 09 Javascript
浅谈移动端之js touch事件 手势滑动事件
Nov 07 Javascript
原生js实现下拉框功能(支持键盘事件)
Jan 13 Javascript
node.js平台下的mysql数据库配置及连接
Mar 31 Javascript
令按钮悬浮在(手机)页面底部的实现方法
May 02 Javascript
移动设备手势事件库Touch.js使用详解
Aug 18 Javascript
67 个节约开发时间的前端开发者的工具、库和资源
Sep 12 Javascript
jQuery pjax 应用简单示例
Sep 20 jQuery
vue 实现锚点功能操作
Aug 10 Javascript
Vue-Ant Design Vue-普通及自定义校验实例
Oct 24 Javascript
vue如何清除浏览器历史栈
May 25 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
德生9700DX电路分析
2021/03/02 无线电
php数组相加 array(“a”)+array(“b”)结果还是array(“a”)
2012/09/19 PHP
PHP基于文件存储实现缓存的方法
2015/07/20 PHP
PHPstorm快捷键(分享)
2017/07/17 PHP
利用PHP访问MySql数据库的逻辑操作以及增删改查的实例讲解
2017/08/30 PHP
PHP使用curl_multi_select解决curl_multi网页假死问题的方法
2018/08/15 PHP
jquery scrollTop方法根据滚动像素显示隐藏顶部导航条
2013/05/27 Javascript
jQuery简单入门示例之用户校验demo示例
2016/07/09 Javascript
JS中用childNodes获取子元素换行会产生一个子元素
2016/12/08 Javascript
jquery uploadify隐藏上传进度的实现方法
2017/02/06 Javascript
微信小程序页面间通信的5种方式
2017/03/31 Javascript
js实现拖拽上传图片功能
2017/08/01 Javascript
javaScript产生随机数的用法小结
2018/04/21 Javascript
JavaScript继承定义与用法实践分析
2018/05/28 Javascript
js for终止循环 跳出多层循环
2018/10/04 Javascript
微信小程序点击顶部导航栏切换样式代码实例
2019/11/12 Javascript
jquery实现吸顶导航效果
2020/01/08 jQuery
Vue项目结合Vue-layer实现弹框式编辑功能(实例代码)
2020/03/11 Javascript
WebStorm中如何将自己的代码上传到github示例详解
2020/10/28 Javascript
在vue中使用eslint,配合vscode的操作
2020/11/09 Javascript
[03:26]回顾2015国际邀请赛中国区预选赛
2015/06/09 DOTA
多个应用共存的Django配置方法
2018/05/30 Python
python3学习之Splash的安装与实例教程
2018/07/09 Python
Python迭代器与生成器基本用法分析
2018/07/26 Python
python执行scp命令拷贝文件及文件夹到远程主机的目录方法
2019/07/08 Python
Windows 下python3.8环境安装教程图文详解
2020/03/11 Python
python re模块常见用法例举
2021/03/01 Python
css3实现文字扫光渐变动画效果的示例
2017/11/07 HTML / CSS
HTML5基于flash实现播放RTMP协议视频的示例代码
2020/12/04 HTML / CSS
Perfume’s Club德国官网:在线购买香水
2019/04/08 全球购物
公务员综合考察材料
2014/02/01 职场文书
素食餐饮项目创业计划书
2014/02/02 职场文书
公司离职证明标准范本
2014/10/05 职场文书
史上最牛的辞职信
2015/02/28 职场文书
工作态度检讨书范文
2015/05/06 职场文书
Golang中channel的原理解读(推荐)
2021/10/16 Golang