App下載

django-admin怎么實(shí)現(xiàn)動(dòng)態(tài)多選框表單

來源: 雨晨的清風(fēng) 2021-08-17 10:21:37 瀏覽數(shù) (3131)
反饋

動(dòng)態(tài)多選框表單是一種常用的表單,因?yàn)楹芏鄷r(shí)候我們需要的表單并不是固定的。動(dòng)態(tài)多選框表單可以給用戶提供一定的自定義空間。借助Django-admin,我們可以簡單快速地實(shí)現(xiàn)動(dòng)態(tài)多選框表單。那么具體要怎么實(shí)現(xiàn)動(dòng)態(tài)多選框表單呢?請(qǐng)繼續(xù)往下看:

背景

背景

借助django-admin,可以快速得到CRUD界面,但若需要?jiǎng)?chuàng)建多選標(biāo)簽字段時(shí),需要對(duì)表單進(jìn)行調(diào)整

示例

model.py

  • 一個(gè)tag(標(biāo)簽類),一個(gè)book(書本類)
  • book攜帶tag,這里不借助有性能問題的外鍵
class tag(models.Model):
    name = models.CharField(max_length=20, verbose_name='標(biāo)簽')
 
 
class book(models.Model):
    name = models.CharField(max_length=50, verbose_name='書名')
    tags = models.TextField(null=True, verbose_name='標(biāo)簽')

 admin.py

將對(duì)應(yīng)的model到admin中注冊(cè),才能被django-admin發(fā)現(xiàn)并使用,所以主要步驟在此,有以下注意點(diǎn):

  • values_list返回:<QuerySet [('tag1', 'tag1'), ('tag2', 'tag2')]>
  • 保證最新標(biāo)簽列表:在表單初始化才執(zhí)行一次標(biāo)簽查詢
  • 表單修改顯示標(biāo)簽:在表單初始化賦值列表對(duì)象
# 標(biāo)簽查詢
def get_tag_list():
    return tag.objects.values_list("name", "name")
 
# 表單類定義
class bookForm(forms.ModelForm):
    tags = forms.MultipleChoiceField(label='標(biāo)簽', widget=widgets.CheckboxSelectMultiple)
 
    def __init__(self, *args, **kwargs):
        super(cameraForm, self).__init__(*args, **kwargs)
        
        # 保證每次初始化有最新的標(biāo)簽列表
        self.fields['tags'].choices = get_tag_list()
        
        # 由于會(huì)在數(shù)據(jù)庫中存儲(chǔ)為列表字符串,需在賦值時(shí)轉(zhuǎn)回列表對(duì)象,才能在修改表單時(shí)識(shí)別原值
        self.initial['tags'] = eval(self.initial['tags'])    
 
    class Meta:
        model = book
        exclude = []
 
# book擴(kuò)展
class bookAdmin(admin.ModelAdmin):
    search_fields = 'name', 'tags')
    list_display = ( 'name', 'tags')
    form = bookForm
 
# 注冊(cè)到admin中
admin.site.register(book, bookAdmin)

處理結(jié)果

寫入到數(shù)據(jù)庫格式

數(shù)據(jù)庫中以列表形式存儲(chǔ)字符串

django表單樣式

處理結(jié)果

以上就是django-admin實(shí)現(xiàn)動(dòng)態(tài)多選框表單的詳細(xì)內(nèi)容,更多django-admin的學(xué)習(xí)資料請(qǐng)關(guān)注W3Cschool其它相關(guān)文章!


0 人點(diǎn)贊