3

我在包含 ImageField 的模型上使用 django ModelForm。为了清楚起见,我在下面包含了一个通用版本,其中删除了一些细节。这个方案对我来说效果很好,我可以毫无问题地上传和显示模型中的图像。

在这种情况下,我的问题是无法通过移动设备进行上传。我在 Iphone 4、Ipad 2 和 Android 手机上进行了测试。所有设备都没有显示任何错误,日志中也没有错误,但是图像根本无法上传。

有谁知道可能导致此问题的原因,或者这是否是 ModelForms 和 ImageFields 的已知问题?我真的很想继续使用 ModelForms,因为我有很多类似的模型,它使维护更容易,但我现在正在研究自定义选项。

到目前为止,谷歌没有提供任何有用的信息。如果有人能指出正确的方向来解决这个问题,将不胜感激。

我的模型看起来像这样(为简洁起见,删除了一些字段):

class myModel(models.Model):
    notes = models.CharField(max_length=2000)
    image = models.ImageField(upload_to="room_images/")
    last_updated = models.DateTimeField(auto_now=True)

我的 ModelForm 看起来像这样,带有一个自定义 TextArea 字段:

class MyForm(forms.ModelForm):
    notes = forms.CharField(widget=forms.Textarea, required=False)

    class Meta:
        model=MyModel

我正在使用与此类似的东西渲染 ModelForm(对象名称更改为通用等效项)。

<form id="myForm" action="{% url my_url %}?param_one={{ object.pk }}&param_two={{ anotherobject.pk }}" enctype="multipart/form-data" method="post">
    {% csrf_token %}
    {{ form.as_p }}
    <input id="saveSomething" class="nice small blue button" type="submit" value="Save" />
</form>

我的观点看起来像这样(为了清楚起见,再次删除了一些东西):

@login_required
def object_edit(request):
    object_id = request.GET.get('param_one', None)
    object2_id = request.GET.get('param_two', None)

    if object_id:
        object = get_object_or_404(myModel, pk=object_id)
        if obejct.userprofile.user != request.user:
            return HttpResponseForbidden()

    if object_id and object2_id != 'None':
        other_object = get_object_or_404(OtherModel, pk=object_id)
    else:
        other_object = OtherModel(object=object)

    if request.POST:
        form = myForm(request.POST, request.FILES, instance=other_object)
        if form.is_valid():
            form.save()
4

1 回答 1

0

通过查看Django 中的表单和文件上传以及data-ajax="false" 的真正作用是什么?,看来您的问题来自 jQuery Mobile。

默认情况下,JQM 将尝试通过 ajax 加载页面以改善用户体验和转换。

显然,当您在 Django 中发布到相同的 URL 并想要手动处理它时,您必须包含

data-ajax="false"

在您的情况下,这意味着将您的模板更改为:

<form id="myForm"
      action="{% url my_url %}?param_one={{ object.pk }}&param_two={{ anotherobject.pk }}"
      enctype="multipart/form-data"
      method="post"
      data-ajax="false"> <!-- change is here -->
    {% csrf_token %}
    {{ form.as_p }}
    <input id="saveSomething" class="nice small blue button" type="submit" value="Save" />
</form>

文档

这告诉框架重新加载整个页面以清除 URL 中的 Ajax 哈希

我自己没有尝试,我只是通过搜索得到的信息。

于 2013-07-17T23:05:42.363 回答