电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

基于django和dropzone.js實現上傳文件

瀏覽:124日期:2024-05-27 16:59:16

1、dropzone.js

http://www.dropzonejs.com/

dropzone.js是一個可預覽可定制化的文件拖拽上傳,實現AJAX異步上傳文件的工具

2、dropzone.js前端界面上傳方式

官網下載 并且引入dropzone.js和dropzone.css(http://www.dropzonejs.com/)以及引用jquery.js,定義一個class='dropzone'即可完成,

代碼示例:

<!DOCTYPE html><html><head> <meta charset='utf-8'> <title>Flask upload with Dropzone example</title> <link rel='stylesheet' href='http://www.hdgsjgj.cn/static/css/dropzone.css' rel='external nofollow' type='text/css' /> <script src='https://rkxy.com.cn/static/js/jquery-3.3.1.js'></script> <script src='https://rkxy.com.cn/static/js/dropzone.js'></script></head><body>

方法1:

<form action='{{ request.path }}' method='POST' enctype='multipart/form-data'></form>//這段代碼是展示dropzone.js的精髓,class一定要是dropzone,id可以自定義<script type='text/javascript'> //第二種配置,這種使用的是div做上傳區域時使用的配置 Dropzone.autoDiscover = false;//不知道該行有什么用,歡迎高手下方評論解答 $('#myAwesomeDropzone').dropzone({ url: '{{ request.path }}', addRemoveLinks: true, method: ’post’, filesizeBase: 1024 });</script>

方法2:

<div class='form-group'> <label class='title'>真人照(最多只能傳一張)</label> <div class='dropzone'></div>//這段代碼是展示dropzone.js的精髓,class一定要是dropzone,id可以自定義</div><input type='hidden' name='file_id' ng-model='file_id' /><script type='text/javascript'>var appElement = document.querySelector(’div .inmodal’); var myDropzone = new Dropzone('#dropz', { url: '{{ request.path }}',//文件提交地址 method:'post', //也可用put paramName:'file', //默認為file maxFiles:1,//一次性上傳的文件數量上限 maxFilesize: 2, //文件大小,單位:MB acceptedFiles: '.jpg,.gif,.png,.jpeg', //上傳的類型 addRemoveLinks:true, parallelUploads: 1,//一次上傳的文件數量 //previewsContainer:'#preview',//上傳圖片的預覽窗口 dictDefaultMessage:’拖動文件至此或者點擊上傳’, dictMaxFilesExceeded: '您最多只能上傳1個文件!', dictResponseError: ’文件上傳失敗!’, dictInvalidFileType: '文件類型只能是*.jpg,*.gif,*.png,*.jpeg。', dictFallbackMessage:'瀏覽器不受支持', dictFileTooBig:'文件過大上傳文件最大支持.', dictRemoveLinks: '刪除', dictCancelUpload: '取消', //對一些方法的后續處理 init:function(){ this.on('addedfile', function(file) {//上傳文件時觸發的事件document.querySelector(’div .dz-default’).style.display = ’none’; }); this.on('success',function(file,data){alert(data.data)//上傳成功觸發的事件console.log(’ok’); }); this.on('error',function (file,data) {//上傳失敗觸發的事件console.log(’fail’);var message = ’’;//lavarel框架有一個表單驗證,//對于ajax請求,JSON 響應會發送一個 422 HTTP 狀態碼,//對應file.accepted的值是false,在這里捕捉表單驗證的錯誤提示if (file.accepted){ $.each(data,function (key,val) { message = message + val[0] + ’;’; }) //控制器層面的錯誤提示,file.accepted = true的時候; alert(message);} }); this.on('removedfile',function(file){//刪除文件時觸發的方法(向后臺發送刪除文件請求){#$.post(’/admin/del/’+ file_id,{’_method’:’DELETE’},function (data) {#}{# console.log(’刪除結果:’+data.message);#}{#})#}document.querySelector(’div .dz-default’).style.display = ’block’; }); } });</script></body></html>

方法二中,很多參數是不一定需要定義的,參見方法一

3、后臺處理dropzone.js前端界面上傳的文件

A、django的settings.py 文件定義上傳文件夾:

#文件上傳文件夾定義ENROLLED_DATA = ’%s/statics/enrolled_data’ %BASE_DIR

B、對應的view處理前端上傳過來的數據:

from django.views.decorators.csrf import csrf_exemptfrom PerfectCRM.settings import *import os@csrf_exemptdef upload(request): if request.method ==’POST’: #post方式 if request.is_ajax(): #如果是ajax請求 if not os.path.exists(ENROLLED_DATA): #如果settings定義的 上傳文件夾不存在os.makedirs(ENROLLED_DATA,exist_ok=True) #新建文件夾 for k,file_obj in request.FILES.items(): #獲取前端傳過來的文件數據with open(’%s/%s’%(ENROLLED_DATA,file_obj.name),'wb') as f: #打開文件 for chunk in file_obj.chunks(): f.write(chunk) #chunk方式寫入文件 return render(request, ’dropzone-back.html’)

C、上傳成功:

基于django和dropzone.js實現上傳文件

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 深圳市东信高科自动化设备有限公司 | 淘趣英语网 - 在线英语学习,零基础英语学习网站 | 衬塑设备,衬四氟设备,衬氟设备-淄博鲲鹏防腐设备有限公司 | 周口市风机厂,周鼓风机,河南省周口市风机厂 | 光泽度计_测量显微镜_苏州压力仪_苏州扭力板手维修-苏州日升精密仪器有限公司 | PTFE接头|聚四氟乙烯螺丝|阀门|薄膜|消解罐|聚四氟乙烯球-嘉兴市方圆氟塑制品有限公司 | 粉末冶金注射成型厂家|MIM厂家|粉末冶金齿轮|MIM零件-深圳市新泰兴精密科技 | 丹佛斯变频器-Danfoss战略代理经销商-上海津信变频器有限公司 | 硅胶管挤出机厂家_硅胶挤出机生产线_硅胶条挤出机_臣泽智能装备 贵州科比特-防雷公司厂家提供贵州防雷工程,防雷检测,防雷接地,防雷设备价格,防雷产品报价服务-贵州防雷检测公司 | 注塑机-压铸机-塑料注塑机-卧式注塑机-高速注塑机-单缸注塑机厂家-广东联升精密智能装备科技有限公司 | 继电器模组-IO端子台-plc连接线-省配线模组厂家-世麦德 | 火锅加盟_四川成都火锅店加盟_中国火锅连锁品牌十强_朝天门火锅【官网】 | 上海新光明泵业制造有限公司-电动隔膜泵,气动隔膜泵,卧式|立式离心泵厂家 | 加中寰球移民官网-美国移民公司,移民机构,移民中介,移民咨询,投资移民 | 合肥白癜风医院_合肥治疗白癜风医院_合肥看白癜风医院哪家好_合肥华研白癜风医院 | 低粘度纤维素|混凝土灌浆料|有机硅憎水粉|聚羧酸减水剂-南京斯泰宝 | 上海赞永| 硬齿面减速机[型号全],ZQ减速机-淄博久增机械 | 大型果蔬切片机-水果冬瓜削皮机-洗菜机切菜机-肇庆市凤翔餐饮设备有限公司 | 电池高低温试验箱-气态冲击箱-双层电池防爆箱|简户百科 | 耐火浇注料价格-高强高铝-刚玉碳化硅耐磨浇注料厂家【直销】 | hdpe土工膜-防渗膜-复合土工膜-长丝土工布价格-厂家直销「恒阳新材料」-山东恒阳新材料有限公司 ETFE膜结构_PTFE膜结构_空间钢结构_膜结构_张拉膜_浙江萬豪空间结构集团有限公司 | 明渠式紫外线杀菌器-紫外线消毒器厂家-定州市优威环保 | 专注提供国外机电设备及配件-工业控制领域一站式服务商-深圳市华联欧国际贸易有限公司 | 河南卓美创业科技有限公司-河南卓美防雷公司-防雷接地-防雷工程-重庆避雷针-避雷器-防雷检测-避雷带-避雷针-避雷塔、机房防雷、古建筑防雷等-山西防雷公司 | 防勒索软件_数据防泄密_Trellix(原McAfee)核心代理商_Trellix(原Fireeye)售后-广州文智信息科技有限公司 | 美的商用净水器_美的直饮机_一级代理经销商_Midea租赁价格-厂家反渗透滤芯-直饮水批发品牌售后 | 皮带式输送机械|链板式输送机|不锈钢输送机|网带输送机械设备——青岛鸿儒机械有限公司 | 黄石妇科医院_黄石东方女子医院_黄石东方妇产医院怎么样 | 权威废金属|废塑料|废纸|废铜|废钢价格|再生资源回收行情报价中心-中废网 | 防火阀、排烟防火阀、电动防火阀产品生产销售商-德州凯亿空调设备有限公司 | 品牌广告服务平台,好排名,好流量,好生意。 | 顺辉瓷砖-大国品牌-中国顺辉 | 深圳法律咨询【24小时在线】深圳律师咨询免费 | 聚合氯化铝_喷雾聚氯化铝_聚合氯化铝铁厂家_郑州亿升化工有限公司 | 网络推广公司_网络营销方案策划_企业网络推广外包平台-上海澜推网络 | Jaeaiot捷易科技-英伟达AI显卡模组/GPU整机服务器供应商 | 硫酸亚铁-聚合硫酸铁-除氟除磷剂-复合碳源-污水处理药剂厂家—长隆科技 | 液压压力机,液压折弯机,液压剪板机,模锻液压机-鲁南新力机床有限公司 | 断桥铝破碎机_发动机破碎机_杂铝破碎机厂家价格-皓星机械 | 安平县鑫川金属丝网制品有限公司,声屏障,高速声屏障,百叶孔声屏障,大弧形声屏障,凹凸穿孔声屏障,铁路声屏障,顶部弧形声屏障,玻璃钢吸音板 |