前端上傳圖片的三種方法
阿新 • • 發佈:2018-06-29
container ID ali multipart spl body KS 上傳 實現ajax
前端上傳圖片的三種方法
Django框架下,在前端上傳文件,保存在數據庫,並在前端不刷新頁面顯示上傳圖片。
- 利用XMLHttpRequest 對象和FormData對象上傳文件
- Ajax上傳文件
- 基於form表單和iframe自己實現ajax請求
1、首先創建數據庫表
class Img(models.Model): path = models.CharField(max_length=128)
更新數據庫
>python manage.py makemigrations
>python manage.py migrate
2、在Django後臺views中定義函數
#前端上傳文件,保存在數據庫,並在前端不刷新頁面顯示上傳圖片 import os,json @csrf_exempt def upload(request): if request.method == ‘GET‘: img_list = models.Img.objects.all() return render(request,‘upload.html‘,{‘img_list‘: img_list}) elif request.method == "POST": user = request.POST.get(‘user‘) fafafa= request.POST.get(‘fafafa‘) obj = request.FILES.get(‘fafafa‘) file_path = os.path.join(‘static‘,‘upload‘,obj.name) f = open(file_path, ‘wb‘) for chunk in obj.chunks(): f.write(chunk) f.close() models.Img.objects.create(path=file_path) ret= {‘status‘: True, ‘path‘: file_path} return HttpResponse(json.dumps(ret))
3、添加urls路徑
url(r‘^upload.html$‘, views.upload),
4、前端文件上傳的三種方法
第一種、XML的方式上傳文件
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> .container img{ width: 200px; height:200px; } </style> </head> <body> <h1>圖片列表</h1> <div class="container" id="imgs"> {% for img in img_list %} <img src="/{{ img.path }}"/> {% endfor %} </div> <input type="file" id="img"> <input type="button" value="提交XML" onclick="UploadXML()"/> <input type="button" value="提交JQ" onclick="Uploadjq()"/> <script src="/static/jquery-2.1.4.min.js"></script> <script> //XML的方式上傳文件,並在頁面不刷新顯示圖片 function UploadXML(){ var dic = new FormData(); dic.append(‘user‘, ‘v1‘); dic.append(‘fafafa‘,document.getElementById(‘img‘).files[0]); var xml = new XMLHttpRequest(); xml.open(‘post‘, ‘/upload.html‘,true); xml.onreadystatechange = function () { if (xml.readyState == 4){ var obj = JSON.parse(xml.responseText); if (obj.status){ var img = document.createElement(‘img‘); img.src = "/" + obj.path; $(‘#imgs‘).append(img); } } }; xml.send(dic); } </script> </body> </html>
第二種、ajax方式上傳文件,並異步顯示
<input type="file" id="img"> <input type="button" value="提交XML" onclick="UploadXML()"/> <input type="button" value="提交JQ" onclick="Uploadjq()"/> <script src="/static/jquery-2.1.4.min.js"></script> <script> //ajax方式上傳文件,並異步顯示 function Uploadjq(){ var dic = new FormData(); dic.append(‘user‘, ‘v1‘); dic.append(‘fafafa‘,document.getElementById(‘img‘).files[0]); $.ajax({ url:‘/upload.html‘, type:‘POST‘, data:dic, processData:false,// tell jQuery not to process the data 默認情況下jquary會對數據做處理 contentType:false, // tell jQuery not to set contentType dataType:‘JSON‘, success: function (arg) { if (arg.status){ var img = document.createElement(‘img‘); img.src = "/" + arg.path; $(‘#imgs‘).append(img); } } }) }
第三種、基於form表單和iframe自己實現ajax請求
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> .container img{ width: 200px; height:200px; } </style> </head> <body> <h1>測試iframe功能</h1> <input type="text" id="url"/> <input type="button" value="點我" onclick="iframChange()"> <iframe id="ifr" src=""></iframe> <hr/> <h1>基於ifram實現form提交</h1> <form action="/upload.html" method="post" target="iframe_1" enctype="multipart/form-data"> <iframe style="display: none" id="iframe_1" name="iframe_1" src="" onload="loadIframe()"></iframe> <input type="text" name="user"/> <input type="file" name="fafafa"/> <input type="submit" value="確定"/> </form> <h1>圖片列表</h1> <div class="container" id="imgs"> {% for img in img_list %} <img src="/{{ img.path }}"/> {% endfor %} </div> <script src="/static/jquery-2.1.4.min.js"></script> <script> //測試 function iframChange(){ var url = $(‘#url‘).val(); $(‘#ifr‘).attr(‘src‘,url); } //基於form表單和iframe自己實現ajax請求 function loadIframe(){ console.log(2); // 獲取iframe內部的內容 var str_json = $(‘#iframe_1‘).contents().find(‘body‘).text(); var obj = JSON.parse(str_json); if (obj.status){ var img = document.createElement(‘img‘); img.src = "/" + obj.path; $(‘#imgs‘).append(img); } } </script> </body> </html>
前端上傳圖片的三種方法