您好,登錄后才能下訂單哦!
這篇文章主要介紹了django-xadmin根據(jù)當(dāng)前登錄用戶動(dòng)態(tài)設(shè)置表單字段默認(rèn)值的示例分析,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
相信你一定會(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='面試部門(mén)') 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)前登錄用戶的身份來(lái)動(dòng)態(tài)設(shè)置默認(rèn)值呢?
要解決這個(gè)問(wèn)題就不能從數(shù)據(jù)庫(kù)層面來(lái)設(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='面試部門(mén)') 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 ... # 需要重寫(xiě)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通過(guò)Ajax利用FormData動(dòng)態(tài)提交表單(包括文件,字符串)
0 需求背景
有的時(shí)候我們上傳表單,經(jīng)過(guò)后臺(tái)處理之后再分發(fā)回原來(lái)頁(yè)面,這時(shí)必定會(huì)刷新這個(gè)頁(yè)面。為了解決這個(gè)問(wèn)題,我們采用JS動(dòng)態(tài)提交表單元素,如:file、text等類型,可以很好的解決這一問(wèn)題。
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('上傳成功!')
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“django-xadmin根據(jù)當(dāng)前登錄用戶動(dòng)態(tài)設(shè)置表單字段默認(rèn)值的示例分析”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。