#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 для просмотра сохраненных данных??