仿ajax 无刷新上传文件(如头像上传等)

我们知道,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>';


?>

相关文章

JS原生Ajax操作(XMLHttpRequest) GET请求 POST请求 兼容性问题 利用iframe模拟ajax 实现表单提交的返回...
AJAX 每日更新前端基础,如果觉得不错,点个star吧 &#128515; https://github.com/WindrunnerMax/E...
踩坑Axios提交form表单几种格式 前后端分离的开发前后端, 前端使用的vue,后端的安全模块使用的SpringSe...
很早就听闻ajax的名声,但是却一直不知道怎么用,今天自己捣鼓了一下,竟然会用了,哈哈哈哈。 为了防止...
需要在服务器上进行哈 jquery的ajax方法: // jquery请求 $.ajax({ url: &quot;./server/slider.js...
Ajax函数封装ajax.js // Get / Post // 参数 get post // 是否异步 // 如何处理响应数据 // URL // var...