如何从Django Mod提交表单

2024-09-28 12:16:40 发布

您现在位置:Python中文网/ 问答频道 /正文

我试图上传视频到我的Django网站使用模态。当前,当我尝试提交表单时,出现错误'NoneType' object has no attribute 'is_ajax'

我一直在阅读Django教程以及bootstrap/html/guides,但我找不到一个关于为什么不提交表单的明确答案。你知道吗

你知道吗基本.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>

上传_视频.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">&times;</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 %}

你知道吗视图.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)

你知道吗型号.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

表格..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()时。我最好的猜测是表单是空的,因为表单是在模态上提交的,它实际上没有保存在网页上。你知道吗

最终目标是表单正确保存,以便视频显示在我的媒体文件夹中。你知道吗


Tags: divform表单modelsrequesthtmlbuttonli

热门问题