久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

django-xadmin根據(jù)當(dāng)前登錄用戶動態(tài)設(shè)置表單字段默認(rèn)值方式

瀏覽:2日期:2024-10-21 10:48:55

相信你一定會設(shè)置一個普通字段的默認(rèn)值:

class Offer(models.Model):salary = models.CharField(max_length=64, blank=True, default=’6000’, verbose_name=’薪資待遇’)

相信你還能動態(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ù)庫模型層面修改,數(shù)據(jù)層面的修改有個缺點,就是針對所有用戶都設(shè)置成同一個默認(rèn)值。

如果我想根據(jù)當(dāng)前登錄用戶的身份來動態(tài)設(shè)置默認(rèn)值呢?

要解決這個問題就不能從數(shù)據(jù)庫層面來設(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方法,此方法作用是生成表單實例 def instance_forms(self): super().instance_forms() # 判斷是否為新建操作,新建操作才會設(shè)置creator的默認(rèn)值 if not self.org_obj: self.form_obj.initial[’creator’] = self.request.user.id

最終效果:

創(chuàng)建者會根據(jù)當(dāng)前登錄用戶自動填入

django-xadmin根據(jù)當(dāng)前登錄用戶動態(tài)設(shè)置表單字段默認(rèn)值方式

補(bǔ)充知識:Django通過Ajax利用FormData動態(tài)提交表單(包括文件,字符串)

0 需求背景

有的時候我們上傳表單,經(jīng)過后臺處理之后再分發(fā)回原來頁面,這時必定會刷新這個頁面。為了解決這個問題,我們采用JS動態(tài)提交表單元素,如:file、text等類型,可以很好的解決這一問題。

1 DOM結(jié)構(gòu)

<form method='post' enctype='multipart/form-data''> <input type='text' > <input type='file'> <select id='models'> <option>model0</option> <option>model1</option> </select> <input type='file'> <input type='button' 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后臺代碼

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)前登錄用戶動態(tài)設(shè)置表單字段默認(rèn)值方式就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Django
相關(guān)文章:
主站蜘蛛池模板: 菏泽市| 凌源市| 甘泉县| 监利县| 平阳县| 凯里市| 巴林左旗| 泸定县| 新乐市| 乌兰察布市| 安西县| 琼结县| 息烽县| 中宁县| 高阳县| 长兴县| 肥东县| 宜城市| 泗洪县| 大足县| 临湘市| 翼城县| 阆中市| 德庆县| 昆明市| 双桥区| 新安县| 芷江| 治多县| 开平市| 南丹县| 乌兰县| 扎兰屯市| 蚌埠市| 长武县| 德州市| 宣汉县| 方城县| 澄迈县| 武乡县| 怀柔区|