как принимать входные данные с одной страницы и отправлять их на другую страницу в django

#django #django-views #django-templates

#django #django-просмотры #django-шаблоны

Вопрос:

Я довольно новичок в этом. Я пытаюсь создать страницу отчета в iframe в соответствии с требованиями пользователя пользователь может создать отчет с src, шириной и высотой…и я успешно сделал это … я могу создать отчет, теперь я хочу, чтобы имя созданного отчета отображалось в выпадающем меню, и когда пользователь нажимает на название отчета, пользователь может видеть отчет, и название отчета будет динамически добавляться в выпадающем списке…. я жду ответа .. здесь я собираюсь поделиться кодом, который я сделал… я бы сказал еще одну вещь, я не хочу добавлять эти данные (Src, width, height, название отчета) в базу данных … возможно ли создать отчет и получить тот же отчет, когда я нажму на название отчета.
index.html

 <li class="dropdown">
    <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">Reports<span class="caret"></span></a>
    <ul class="dropdown-menu">
        <li class="dropdown-header">Reports</li>
        <li>
            <div class="buttons pull-right">
                <a href="{% url 'report:reporttest' %}" class="btn btn-xs btn-success" title="Add"><i class="fa fa-plus"></i></a>
            </div>
            <a href="{% url 'report:reporttwo' %}">Report one</a>
        </li>
        {% for item in report_item %}
        <li>
            <a href="{% url 'report:add' %}">{{item.name}}</a>
        </li>
        {% endfor %}
    </ul>
</li>
  

reportform.html

 <form action = "add" method= "post" enctype="multipart/form-data" class="form form-horizontal">  
    {% csrf_token %}
    <div class="panel panel-default">
        <div class="panel-heading">
            <strong>Add Report</strong>
        </div>
        <div class="panel-body">
            <table class="table table-hover report-body attr-table">
                <tr>
                    <td>URL</td>
                    <td>
                        <input type="text" name="src">
                    </td>
                </tr>
                <tr>
                    <td>WIDTH</td>
                    <td>
                        <input type="number" name="width">
                    </td>
                </tr>
                <tr>
                    <td> HEIGHT</td>
                    <td>
                        <input type="number" name="height">
                    </td>
                </tr>
                <tr>
                    <td> NAME OF THE REPORT</td>
                    <td>
                        <input type="text" name="name">
                    </td>
                </tr>
            </table>
            <input type="submit">
        </div>
    </div>
</form>
  

report_one.html

 <iframe src = {{src}} width= {{width}} height= {{height}} frameborder="0" allowfullscreen allowtransparency ></iframe>
  

**view.py **

 def reportone(request):
    return render(request, 'report_one.html')
def reporttwo(request):
    return render(request, 'report_two.html')
def reporttest(request):
    return render(request, 'reportform.html')

def add(request):
    if request.method == "POST":
        report_item={}
        src=request.POST['src']
        width=request.POST['width']
        height=request.POST['height']
        name=request.POST['name']
        report_item={'src':src, 'width':width, 'height':height, 'name':name}
        return render(request, 'report_one.html', report_item)
    else:
        return render(request, 'report_one.html' , report_item)
  

urls.py

 from django.contrib import admin
from django.urls import path
from extras.views import ObjectChangeLogView
from . import views

   app_name = 'report'

   urlpatterns = [
      path('reportone', views.reportone, name='reportone'),
      path('reporttwo', views.reporttwo, name='reporttwo'),
      path('reporttest', views.reporttest, name='reporttest'),
      path('add', views.add, name='add'),
    ] 
  

Комментарии:

1. пожалуйста, добавьте свой urls.py файл для большего понимания

2. @RiyasAc готово, и я также обновил словарь отчетов

Ответ №1:

Пожалуйста, попробуйте это:

models.py

 from django.db import models
class Report(models.Model):
    url = models.URLField(null=False,max_length=300)
    width = models.IntegerField(default=300)
    height = models.IntegerField(default=200)
    name = models.CharField(max_length = 50)
  

forms.py

 from .models import Report
from django.db import models

class ReportForm(forms.Form):
    width = forms.CharField(widget=forms.NumberInput(attrs={'class':' form-control'}))
    height = forms.CharField(widget=forms.NumberInput(attrs={'class':' form-control'}))
    url = forms.URLField(max_length=300)
    name = forms.CharField(max_length = 50)

    class Meta:
        model   = Report
        fields  = [ "url","width","height","name"]
  

views.py

 from .forms import ReportForm
from .models import Report

def reporttest(request):
    form = ReportForm()
    return render(request, 'reportform.html',{'form':form})

def add(request):
    report_item={}
    if request.method == "POST":
        obj= Report()
        obj.url =request.POST['url']
        obj.width=request.POST['width']
        obj.height=request.POST['height']
        obj.name=request.POST['name']
        obj.save()
        report_item={'src':request.POST['url'], 'width':request.POST['width'], 'height':request.POST['height'], 'name':request.POST['name']}
        return render(request, 'report_one.html', report_item)
    else:
        return render(request, 'report_one.html' , report_item)
  

reportform.html

 <form action = "add" method= "post" enctype="multipart/form-data" class="form form-horizontal">  
  <div class="panel panel-default">
    <div class="panel-heading">
        <strong>Add Report</strong>
    </div>
    <div class="panel-body">
        <table class="table table-hover report-body attr-table">
            {% csrf_token %}
            {% for field in form.visible_fields %}
            <tr>
                <td>{{field.label}}</td>
                <td>{{field}}</td>
            </tr>  
            {% endfor %}
        </table>
        <input type="submit" >
    </div>
</div>
</form>
  

report_one.html

 <iframe width="{{width}}" height="{{height}}" src="{{src}}" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>
  

пожалуйста, попробуйте это.После изменения модели перенесите ее.
простой URL для проверки:https://www.youtube.com/embed/F5mRW0jo-U4
введите описание изображения здесь

Комментарии:

1. не работает… у меня нет имени отчета в выпадающем списке

2. index.html не используется в представлениях?? Вы забыли добавить какое-либо представление в views.py ??

3. если я внес некоторые изменения в index.html например, {{ name }} без цикла for, тогда я могу видеть имя отчета, но когда я нажимаю на имя, это не показывает созданный отчет, я нашел ошибку страница не найдена, и после щелчка по имени отчета в выпадающем списке имя имени отчета также удаляется … я хочу, чтобы все имя создать отчет в выпадающем списке

4. пожалуйста, сохраните созданные сведения в новой таблице и отфильтруйте название отчета для выпадающего списка

5. Вам нужен reporttest URL для добавления отчета и add URL для просмотра сохраненных данных??