Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/image-processing/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何在django管理表单中添加动态html5数据属性_Django_Django Admin - Fatal编程技术网

如何在django管理表单中添加动态html5数据属性

如何在django管理表单中添加动态html5数据属性,django,django-admin,Django,Django Admin,我只是想问一下,我们如何在django管理表单中的每个域中添加额外的动态html5数据属性 比如说 <option value ="1" data-desc="desc1">hello1</option> <option value ="2" data-desc="desc2">hello2</option> hello1 你好 谢谢 Kel您可以使用该方法调整ModelAdmin使用的表单 这样,您可以更改相关字段的小部件:

我只是想问一下,我们如何在django管理表单中的每个域中添加额外的动态html5数据属性

比如说

    <option value ="1" data-desc="desc1">hello1</option>
    <option value ="2" data-desc="desc2">hello2</option>
hello1
你好
谢谢

Kel

您可以使用该方法调整
ModelAdmin
使用的表单

这样,您可以更改相关字段的小部件:

class MyModelAdmin(admin.ModelAdmin):
    def get_form(self, request, obj=None, **kwargs):
        form = super(MyModelAdmin, self).get_form(request, obj, **kwargs)
        form.fields['your_field'].widget.attrs.update({'data-hello': 'world'})
        return form

您需要对Django的ModelChoiceField进行子类化,并修改它的
render\u options()
render\u option()
方法,以显示所需的对象属性。我猜您还需要自己的ModelChoiceInterator子类,这样它不仅可以输出id/标签元组,还可以输出您需要的所有数据

例子 我刚刚在中找到了一个自定义SelectWidget的实现:


但是如果我想要一个动态数据属性呢。像管理员中的dropdow列表项?谢天谢地,使用Django 1.7和普通的ModelChoiceField对我来说不是开箱即用的。我必须重写label_from_instance方法,如下所示:
def label_from_instance(self,obj):return obj
对于这样简单的任务来说,这太复杂了。Django必须做点什么。
class SelectWidget(widgets.Select):
    """
    Customizable select widget, that allows to render
    data-xxx attributes from choices.

    .. attribute:: data_attrs

        Specifies object properties to serialize as
        data-xxx attribute. If passed ('id', ),
        this will be rendered as:
        <option data-id="123">option_value</option>
        where 123 is the value of choice_value.id

    .. attribute:: transform

        A callable used to render the display value
        from the option object.
    """

    def __init__(self, attrs=None, choices=(), data_attrs=(), transform=None):
        self.data_attrs = data_attrs
        self.transform = transform
        super(SelectWidget, self).__init__(attrs, choices)

    def render_option(self, selected_choices, option_value, option_label):
        option_value = force_unicode(option_value)
        other_html = (option_value in selected_choices) and \
                         u' selected="selected"' or ''
        if not isinstance(option_label, (basestring, Promise)):
            for data_attr in self.data_attrs:
                data_value = html.conditional_escape(
                    force_unicode(getattr(option_label,
                                          data_attr, "")))
                other_html += ' data-%s="%s"' % (data_attr, data_value)

            if self.transform:
                option_label = self.transform(option_label)
        return u'<option value="%s"%s>%s</option>' % (
            html.escape(option_value), other_html,
            html.conditional_escape(force_unicode(option_label)))
def formfield_for_foreignkey(self, db_field, request, **kwargs):
        if db_field.name == 'dummy':
            widget = SelectWidget(data_attrs=('bar',))
            choices = [(foo.id, foo) for foo in Foo.objects.all()]
            form_field = forms.ChoiceField(
                choices=choices, widget=widget)
            return form_field
        return super().formfield_for_foreignkey(db_field, request, **kwargs)