利用H5特性FormData實現(xiàn)不刷新文件上傳
之前朋友說的不刷新上傳文件。最暴力的解決方案就是上網(wǎng)上搜各種JS庫,附帶多圖上傳,預(yù)覽,甚至是圖片處理等特技。那么如果不接觸第三方的庫,可不可以利用ajax來做。就這個問題,有人給出的解決方案是借助iframe,這里就不贅述了。但是Html5是個好東西,他提供了FormData,F(xiàn)ormData可以幫助我們拼湊參數(shù),乃至文件資源。這樣,我們就可以輕松用$.ajax不刷新上傳。當然也不需要iframe。
代碼
下列是前端部分。
<!DOCTYLE html> <meta charset=utf-> <head> <script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/../jquery.min.js"></script> </head> <script type="text/javascript"> $(function(){ $('#add').submit(function(){ var data = new FormData($('#add')[]); console.log(data); $.ajax({ url: 'ajax.php', type: 'POST', data: data, dataType: 'JSON', cache: false, processData: false, contentType: false, success:function(data){ //alert(data); alert("UploadFile Success"); } }); return false; }); }); </script> <form id='add'> <input type="text" name='book'></input> <input type="file" name='source'></input> <input type="submit"> </form>
不多贅述里面的代碼,就講一行代碼
var data = new FormData($('#add')[0]);
FormData是一個表單對象,他可以將表單對象的表單域分別形成key=>value。那么是不是我們自己再拼接額外的key=>value呢,答案是可以的,詳情可以百度FormData。
還有就是為什么是$('#add')[0]?
我只能說 js = jQuery[0];
PHP部分
<?php header('Content-Type:application/json; charset=utf-8'); echo json_encode(array($_FILES,$_REQUEST)); ?>
這邊只是做下測試,如果能看到$_FILES有東西,那么證明我們是可以做上傳的。
測試上傳
可以看到ajax請求到了ajax.php
看下preview,就可以看到返回$_FILES的相關(guān)信息了。
相關(guān)文章
配置Chrome支持本地(file協(xié)議)的AJAX請求
這篇文章主要為大家詳細介紹了配置Chrome支持本地(file協(xié)議)的AJAX請求 ,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06基于ajax后臺返回的數(shù)據(jù)為空前臺顯示出現(xiàn)undefined的解決方法
今天小編就為大家分享一篇基于ajax后臺返回的數(shù)據(jù)為空前臺顯示出現(xiàn)undefined的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08Ajax學(xué)習(xí)全套(最全最經(jīng)典)
ajax是指一種創(chuàng)建交互式網(wǎng)頁應(yīng)用的網(wǎng)頁開發(fā)技術(shù)。這篇文章主要介紹了Ajax學(xué)習(xí)全套(最全最經(jīng)典)的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-08-08asp.net 全部選中與取消操作,選中后的刪除(ajax)實現(xiàn)無刷新效果
現(xiàn)在我們在編程的時刻總是要利用一些最新的技術(shù)去解決問題。。。。下面是我用ajax與jequery結(jié)合在一起使用的一個實例。希能給一起學(xué)習(xí)的朋友們帶來幫助。2009-06-06使用$.getJSON實現(xiàn)跨域ajax請求示例代碼
getJSON調(diào)用并獲取遠程的JSON字符串,將其轉(zhuǎn)換為JSON對象,如果成功,則執(zhí)行回調(diào)函數(shù),下面有個不錯的示例,需要的朋友可以參考下2013-11-11用ajax傳遞json到前臺中文出現(xiàn)問號亂碼問題的解決辦法
這篇文章主要介紹了用ajax傳遞json到前臺中文出現(xiàn)問號亂碼問題的解決辦法,需要的朋友參考下2017-01-01