gpt4 book ai didi

Django ModelForm ImageField

转载 作者:行者123 更新时间:2023-12-02 08:18:49 26 4
gpt4 key购买 nike

我有一个模型和一个表单 (forms.ModelForm),其中有一个 ImageField。该模型类似于:

class Business(models.Model):
business_name = models.CharField(max_length=128)
.
.
business_image = ImageField(
max_length=128,
upload_to=upload_business_image_handler,
height_field='business_image_height',
width_field='business_image_width'
)
business_image_height = models.IntegerField(blank=True, null=True)
business_image_width = models.IntegerField(blank=True, null=True)
.
.

随附表格:

class BusinessForm(forms.ModelForm):
def __init__(self, data=None, files=None, branch_list = None, country_list = None, *args, **kwargs):
super(BusinessForm, self).__init__(data, *args, **kwargs)
# create the MultipleChoiceField choice_list based on language
self.fields['branch'].choices = branch_list
self.fields['country'].choices = country_list
self.postdata = data
self.files = files

business_name = forms.CharField(widget=forms.TextInput(attrs={'size':'50', 'class': 'address'}), required=True)

#business_image = forms.ImageField(widget=forms.ClearableFileInput())

表单中的最后一行被注释掉,因为 forms.ClearableFileInput() 是 FileFields 和 ImageFields 的默认小部件。

现在,当使用此表单编辑现有记录时,模板中的图像如下所示:

Currently: <image_url>
Change: <browse_button>

我想更改文本标签“当前”和“更改”,而不是显示 image_url 我想显示图像。

当然,我可以复制和修改“site-packages/django/forms/widgets.py”中找到的“class ClearableFileInput(FileInput)”代码,但我想知道这是否是实现此目的的方法。

如有任何帮助或建议,我们将不胜感激。

现在我查看了“class ClearableFileInput(FileInput)”的代码

最佳答案

这是我对同一问题的解决方案。

from django.utils.safestring import mark_safe
from django.utils.html import escape, conditional_escape
from django.utils.encoding import force_unicode
from django.forms.widgets import ClearableFileInput, Input, CheckboxInput

class CustomClearableFileInput(ClearableFileInput):

def render(self, name, value, attrs=None):
substitutions = {
#uncomment to get 'Currently'
'initial_text': "", # self.initial_text,
'input_text': self.input_text,
'clear_template': '',
'clear_checkbox_label': self.clear_checkbox_label,
}
template = '%(input)s'
substitutions['input'] = Input.render(self, name, value, attrs)

if value and hasattr(value, "url"):
template = self.template_with_initial
substitutions['initial'] = ('<img src="%s" alt="%s"/>'
% (escape(value.url),
escape(force_unicode(value))))
if not self.is_required:
checkbox_name = self.clear_checkbox_name(name)
checkbox_id = self.clear_checkbox_id(checkbox_name)
substitutions['clear_checkbox_name'] = conditional_escape(checkbox_name)
substitutions['clear_checkbox_id'] = conditional_escape(checkbox_id)
substitutions['clear'] = CheckboxInput().render(checkbox_name, False, attrs={'id': checkbox_id})
substitutions['clear_template'] = self.template_with_clear % substitutions

return mark_safe(template % substitutions)

然后只需使用扩展小部件:

business_image = forms.ImageField(widget=CustomClearableFileInput())

关于Django ModelForm ImageField,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10822111/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com