django-xadmin根據(jù)當(dāng)前登錄用戶動(dòng)態(tài)設(shè)置表單字段默認(rèn)值方式
相信你一定會(huì)設(shè)置一個(gè)普通字段的默認(rèn)值:
class Offer(models.Model):
salary = models.CharField(max_length=64, blank=True, default='6000', verbose_name='薪資待遇')
相信你還能動(dòng)態(tài)設(shè)置外鍵字段的默認(rèn)值:
class Interview(models.Model): department = models.ForeignKey('departments.Department', related_name='interview', on_delete=models.PROTECT, default=get_department, verbose_name='面試部門') def get_department(): department = Department.objects.get(name='管理部') return department.id
但是以上都是從數(shù)據(jù)庫(kù)模型層面修改,數(shù)據(jù)層面的修改有個(gè)缺點(diǎn),就是針對(duì)所有用戶都設(shè)置成同一個(gè)默認(rèn)值。
如果我想根據(jù)當(dāng)前登錄用戶的身份來動(dòng)態(tài)設(shè)置默認(rèn)值呢?
要解決這個(gè)問題就不能從數(shù)據(jù)庫(kù)層面來設(shè)置了,而要在adminx.py文件中去設(shè)置。
class Interview(models.Model): hruser = models.ForeignKey(HrUser, related_name='interview', on_delete=models.PROTECT, verbose_name='姓名') department = models.ForeignKey('departments.Department', related_name='interview', on_delete=models.PROTECT, verbose_name='面試部門') creator = models.ForeignKey(settings.AUTH_USER_MODEL, related_name='creator', on_delete=models.PROTECT, verbose_name='創(chuàng)建者') @register(Interview) class InterviewAdmin(InterviewSrv): list_display = ('hruser', 'status', 'department', 'creator', ...) list_per_page = 50 ... # 需要重寫instance_forms方法,此方法作用是生成表單實(shí)例 def instance_forms(self): super().instance_forms() # 判斷是否為新建操作,新建操作才會(huì)設(shè)置creator的默認(rèn)值 if not self.org_obj: self.form_obj.initial['creator'] = self.request.user.id
最終效果:
創(chuàng)建者會(huì)根據(jù)當(dāng)前登錄用戶自動(dòng)填入
補(bǔ)充知識(shí):Django通過Ajax利用FormData動(dòng)態(tài)提交表單(包括文件,字符串)
0 需求背景
有的時(shí)候我們上傳表單,經(jīng)過后臺(tái)處理之后再分發(fā)回原來頁面,這時(shí)必定會(huì)刷新這個(gè)頁面。為了解決這個(gè)問題,我們采用JS動(dòng)態(tài)提交表單元素,如:file、text等類型,可以很好的解決這一問題。
1 DOM結(jié)構(gòu)
<form method="post" enctype="multipart/form-data""> <input id="subject" type="text" class="form-control" > <input id="excels" type="file"> <select class="form-control" id="models"> <option>model0</option> <option>model1</option> </select> <input id="con" type="file"> <input type="button" id="showyulan" value="上傳"> </form>
2 JS代碼
$('#showyulan').click(function () { var formData = new FormData(); formData.append('subject', $('#subject').val()) formData.append('excels', document.getElementById("excels").files[0]) formData.append('models', $('#models').val()) formData.append('con', document.getElementById("con").files[0]) formData.append('qunfasum', $('#qunfasum').val()) formData.append('jiange', $('#jiange').val()) formData.append('yuming', $('#yuming').val()) formData.append('duankou', $('#duankou').val()) $.ajax({ url:"/showyulan/", type:"POST", data:formData, processData:false, contentType:false, success: function (data) { alert(data) } }) })
3 Django后臺(tái)代碼
def showyulan(request): subject = request.POST.get('subject') f1 = request.FILES.get('excels') # 文件保存路徑 fname = '%s/excel/%s' % (settings.MEDIA_ROOT, f1.name) with open(fname, 'wb') as pic: for c in f1.chunks(): pic.write(c) models = request.POST.get('models') f2 = request.FILES.get('con') # 文件保存路徑 fname = '%s/text/%s' % (settings.MEDIA_ROOT, f2.name) with open(fname, 'wb') as pic: for c in f2.chunks(): pic.write(c) return HttpResponse('上傳成功!')
以上這篇django-xadmin根據(jù)當(dāng)前登錄用戶動(dòng)態(tài)設(shè)置表單字段默認(rèn)值方式就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
python cookie反爬處理的實(shí)現(xiàn)
這篇文章主要介紹了python cookie反爬處理的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11Java Spring項(xiàng)目國(guó)際化(i18n)詳細(xì)方法與實(shí)例
這篇文章主要介紹了Java Spring項(xiàng)目國(guó)際化詳細(xì)方法與實(shí)例,需要的朋友可以參考下2020-03-03Pandas中Concat與Append的實(shí)現(xiàn)與區(qū)別小結(jié)
本文主要介紹了Pandas中Concat與Append的實(shí)現(xiàn)與區(qū)別小結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-11-11Pygame游戲開發(fā)之太空射擊實(shí)戰(zhàn)添加圖形篇
相信大多數(shù)8090后都玩過太空射擊游戲,在過去游戲不多的年代太空射擊自然屬于經(jīng)典好玩的一款了,今天我們來自己動(dòng)手實(shí)現(xiàn)它,在編寫學(xué)習(xí)中回顧過往展望未來,在本課中,我們將討論如何在游戲中使用預(yù)先繪制的圖形2022-08-08python中無法導(dǎo)入本地安裝好的第三方庫(kù)問題
這篇文章主要介紹了python中無法導(dǎo)入本地安裝好的第三方庫(kù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02