假设我有一个博客网站。每个博客都由图像组成。所以,我想根据它们所属的博客对图像进行排序。但是在上传的时候,如何自动将博客ID与图片一起传递呢?
我有这样的模型:
class Blog(models.Model):
name = models.CharField()
blog = models.CharField()
class Photo(models.Model):
blog = models.ForeignKey(Blog, on_delete=models.CASCADE)
file = models.FileField(upload_to=get_upload_path)
我的 forms.py 看起来像:
class PhotoForm(forms.ModelForm):
class Meta:
model = Photo
fields = ('file', 'blog')
您会在字段中看到“博客”。我实际上如何在那里传递博客 ID?
目前,我的上传页面的html是这样的:
<div style="margin-bottom: 20px;">
<button type="button" class="btn btn-primary js-upload-photos">
<input id="fileupload" type="file" name="file" multiple
style="display: none;"
data-url="{% url 'blog' blog.id %}"
data-form-data='{"csrfmiddlewaretoken": "{{ csrf_token }}"}'>
</div>
实际上,这种上传图片的方式取自Vitor Freitas 的这篇精彩文章
现在,我想通过views.py 将博客ID 传递给模板,其中包含我已经完成的上下文。但是我如何保存它并与我上传的图像一起传递呢?
views.py 看起来像:
class BlogDetailView(View):
def get(self, request,**kwargs):
page = get_object_or_404(Page, pk=self.kwargs['pk'])
context = {'page':page}
return render(self.request, 'blog.html', context=context)
def post(self, request, **kwargs):
form = PhotoForm(self.request.POST, self.request.FILES)
if form.is_valid():
photo = form.save()
data = {'is_valid': True, 'name': photo.file.name, 'url': photo.file.url}
else:
data = {'is_valid': False}
return JsonResponse(data)
那么如何在上传时将图片与博客相关联?
任何帮助将不胜感激。