仿ajax 无刷新上传文件(如头像上传等)
发布时间:2020-12-16 02:12:47 所属栏目:百科 来源:网络整理
导读:我们知道,js及ajax是无法操作文件的,当然,现在新出的xhr2标准已经包含文件上传API,但是,毕竟是新标准,那些老旧的浏览器,依然不支持,我们不能强制要求别人不用IE8这样的浏览器,所以还是需要有个兼容的办法。这就是这篇blog要提到的,无刷新上传。 原
我们知道,js及ajax是无法操作文件的,当然,现在新出的xhr2标准已经包含文件上传API,但是,毕竟是新标准,那些老旧的浏览器,依然不支持,我们不能强制要求别人不用IE8这样的浏览器,所以还是需要有个兼容的办法。这就是这篇blog要提到的,无刷新上传。 原理:使用form表单的 target属性,我们把目标指向本页面的iframe, 然后,我们将iframe 用css隐藏, 接着,我们在后台操作文件程序,调用前台的js程序,将返回结果显示在当前页面上。 上代码: 前台html 部分:
<script type="text/javascript"> function pic(url){ var div3 = document.getElementById('div3'); div3.style.background ="url("+url+")"; } </script> <style type="text/css"> .div2{width:0;height:0} #div3{width:100px;height:100px;} iframe{width:0;height:0;} </style> </head> <body> <div class="div1"> <form method="post" enctype="multipart/form-data" target="head_userpic" action="upload.php"> <input type="file" name="pic" /> <input type="submit" value="上传"/> </form> </div> <div class="div2"> <iframe frameborder=0 name="head_userpic"></iframe> </div> <div id="div3"></div> </body> </html>
后台php部分
<?php header("content-type:text/html;charset=utf8"); $dir = $_FILES["pic"]["tmp_name"]; $name = $_FILES["pic"]["name"]; move_uploaded_file($dir,'./'.$name); echo '<script>parent.pic("'.'./'.$name.'");</script>'; ?> (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |