php iframe 上传图片,PHP+iframe模拟Ajax上传文件功能示例

本文实例讲述了PHP+iframe模拟Ajax上传文件功能。分享给大家供大家参考,具体如下:

在xmlhttprequest level 1中,Ajax是不能够上传文件的,因为js不能操作本地文件,但是市场上有一些Ajax异步上传文件的插件,是怎么完成的呢?答案:可以使用iframe模拟Ajax上传文件。接下来博主将使用iframe来模拟Ajax来上传文件。

首先看一下效果图:

c6d5c05f1d7c5d9d460a287c0efa38a1.gif

文件结构图:

60fc569031098b7b862c3d0ebeef33fe.png

09-iframe-upload.html文件:

页面中有一个表单,表单中有一个上传文件按钮和提交按钮,点击提交按钮执行ajaxUpload函数,然后动态创建iframe标签,让其不可见,最后设置表单的target属性指向iframe。

iframe模拟Ajax上传文件

/**

* 文件上传

* @return bool 是否提交表单

* 1、捕捉表单提交的动作

* 2、动态创建iframe标签,然其不可见

* 3、设置表单的target属性指向iframe

*/

function ajaxUpload(){

var iframeName = 'upload'+Math.random();//给iframe取名

$('').appendTo($('body'));//动态创建iframe

$('form:first').attr('target',iframeName);//设置form的target属性

$('#progress').html('progress.jpg');//显示上传是否成功

//return false;

}

iframe模拟Ajax上传文件

09-iframe-upload.php文件:

首先延时3秒,为了能看到加载的图片,然后判断是否有上传文件,然后返回一段Js代码,这段js是在页面中显示是否上传成功

/**

* iframe模拟Ajax上传文件

* @author webbc

*/

sleep(3);//延时3秒

if(empty($_FILES)){

echo 'no file';

}

$error = $_FILES['pic']['error'] == 0?'succ':'fail';//判断上传是否成功

echo "";//显示上传是否成功

?>

希望本文所述对大家PHP程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值