Я пытаюсь загрузить видео на мой сайт Django, используя модальное. В настоящее время, когда я пытаюсь отправить форму, я получаю сообщение об ошибке 'NoneType' object has no attribute 'is_ajax'
Я просматривал учебные пособия по Django, а также начальную загрузку / html / guides. Я не могу найти четкий ответ, почему форма не соответствуетпредставления.
base.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.0/js/bootstrap.min.js"></script>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
<!-- Our style.css -->
{% load static %}
<link rel="stylesheet" href="/static/VR360/style.css?{% now "U" %}"/>
<title>Umbra</title>
</head>
<body>
<ul>
<li><a href="#login">Login</a></li>
<li><a href="{% url 'upload-videos' %}">Upload Videos</a></li>
<li><a href="{% url 'homepage' %}">Home</a></li>
</ul>
<!-- Everything that extends base.html, the code will be "inside" these two block content commands-->
<div id="page-wrap">
{% block content %}
{% endblock content %}
</div>
</body>
</html>
upload_videos.html
{% extends "VR360/base.html" %}
{% block content %}
<h1>Upload Videos</h1>
<button type="button" class="btn btn-primary btn-lg" data-toggle="modal" data-target="#myModal">
Launch demo modal
</button>
<!-- Modal -->
<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel">
<form method="post" enctype="multipart/form-data">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button>
<h4 class="modal-title" id="myModalLabel">Modal title</h4>
</div>
<div class="modal-body">
{% csrf_token %}
{{ form.as_p }}
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary">Upload File</button>
</div>
</div>
</div>
</form>
</div>
{% endblock %}
views.py
class VideoCreateView(BSModalCreateView):
template_name = 'VR360/upload-videos.html'
form_class = VideoForm
def get(self, request):
form = VideoForm()
videos = Video.objects.all()
context = {'form': form, 'videos': videos}
return render(request, 'VR360/upload-videos.html', context)
def post(self, request):
form = VideoForm(request.POST, request.FILES)
form = self.form_class(request.POST, request.FILES)
if form.is_valid():
form.save()
videos = Video.objects.all()
context = {'form': form, 'videos': videos}
return render(request, 'VR360/upload-videos.html', context)
models.py
from django.db import models
# Create your models here.
class Video(models.Model):
video = models.FileField(upload_to='videos/')
comment = models.CharField(max_length=100)
def __str__(self):
return self.comment
form..py
from django import forms
from bootstrap_modal_forms.forms import BSModalForm
from .models import Video
class VideoForm(BSModalForm):
class Meta:
model = Video
fields = ['video', 'comment']
Ошибка возникает при попытке form.save()
. Мое лучшее предположение, что форма пуста, потому что форма представлена на модальной странице, но на самом деле она не сохраняется на веб-странице.
Конечной целью будет правильное сохранение формы, чтобы видео отображалось в моей папке мультимедиа.