فهرست سرفصل‌های Django
خانه (Home) مقدمه (Intro) شروع به کار (Get Started) ساخت محیط مجازی (Create Virtual Environment) نصب (Install Django) ساخت پروژه (Create Project) ساخت اپ (Create App) ویوها (Views) آدرس ها (URLs) قالب ها (Templates) مدل ها (Models) افزودن داده (Insert Data) به روزرسانی داده (Update Data) حذف داده (Delete Data) به روزرسانی مدل (Update Model) آماده سازی قالب و ویو (Prep Template and View) افزودن لینک به جزئیات (Add Link to Details) افزودن قالب مادر (Add Master Template) افزودن صفحه ایندکس اصلی (Add Main Index Page) قالب 404 (404 Template) افزودن ویوی تست (Add Test View) پنل مدیریت (Admin) ساخت کاربر (Create User) افزودن مدل ها (Include Models) تنظیم List Display (Set List Display) به روزرسانی اعضا (Update Members) افزودن اعضا (Add Members) حذف اعضا (Delete Members) متغیرها (Variables) تگ ها (Tags) شرط if/else (If Else) حلقه for (For Loop) کامنت (Comment) include (Include) معرفی QuerySet (QuerySet Introduction) متد get (QuerySet Get) فیلتر (QuerySet Filter) مرتب سازی (QuerySet Order By) افزودن فایل های استاتیک (Add Static Files) نصب WhiteNoise (Install WhiteNoise) جمع آوری فایل های استاتیک (Collect Static Files) افزودن فایل های استاتیک سراسری (Add Global Static Files) افزودن استایل به پروژه (Add Styles to the Project) مقدمه (PostgreSQL Intro) ساخت حساب AWS (Create AWS Account) ساخت دیتابیس در RDS (Create Database in RDS) اتصال به دیتابیس (Connect to Database) افزودن اعضا (Add Members) Elastic Beanstalk (EB) ساخت requirements.txt (Create requirements.txt) ساخت django.config (Create django.config) ساخت فایل zip (Create .zip File) استقرار با EB (Deploy with EB) به روزرسانی پروژه (Update Project) افزودن فیلد slug (Add Slug Field) افزودن Bootstrap 5 (Add Bootstrap 5) مرجع تگ های قالب (Template Tag Reference) مرجع فیلترها (Filter Reference) مرجع Field Lookups (Field lookups Reference) کامپایلر (Compiler) تمرین ها (Exercises) آزمون (Quiz) سرفصل (Syllabus) برنامه مطالعه (Study Plan) سرور (Server) گواهینامه (Certificate)
نتیجه‌ای برای جستجو یافت نشد.
Django

Django — افزودن صفحه ایندکس اصلی (Add Main Index Page)

آخرین بروزرسانی: 1404/08/20

افزودن صفحه ایندکس اصلی (Add Main Index Page)

می خواهیم «صفحه ایندکس اصلی (Main Index Page)» بسازیم. این صفحه وقتی ریشه سایت باز می شود نشان داده می شود. با یک قالب ساده شروع می کنیم، سپس ویو و مسیر (URL) را اضافه می کنیم.

ساخت قالب main.html

یک فایل main.html بساز و از قالب مادر ارث ببر. سپس عنوان و محتوا را پر کن.

{% extends "master.html" %}

{% block title %}
  My Tennis Club
{% endblock %}


{% block content %}
  <h1>My Tennis Club</h1>

  <h3>Members</h3>
  
  <p>Check out all our <a href="members/">members</a></p>
  
{% endblock %}

مشاهده در ادیتور

تعریف ویو main برای ریشه سایت

یک ویو به نام main بساز. این ویو قالب main.html را رندر می کند.

from django.http import HttpResponse
from django.template import loader
from .models import Member

def members(request):
  mymembers = Member.objects.all().values()
  template = loader.get_template('all_members.html')
  context = {
    'mymembers': mymembers,
  }
  return HttpResponse(template.render(context, request))
  
def details(request, id):
  mymember = Member.objects.get(id=id)
  template = loader.get_template('details.html')
  context = {
    'mymember': mymember,
  }
  return HttpResponse(template.render(context, request))
  
def main(request):
  template = loader.get_template('main.html')
  return HttpResponse(template.render())

مشاهده در ادیتور

وصل کردن ریشه سایت به ویو

در urls.py مسیر ریشه را به ویو main وصل کن.

from django.urls import path
from . import views

urlpatterns = [
  path('', views.main, name='main'),
  path('members/', views.members, name='members'),
  path('members/details/<int:id>', views.details, name='details'),
]

مشاهده در ادیتور

دکمه برگشت به صفحه اصلی

در لیست اعضا یک لینک بازگشت به ریشه اضافه کن تا کاربر راحت برگردد.

{% extends "master.html" %}

{% block title %}
  My Tennis Club - List of all members
{% endblock %}


{% block content %}
  
  <p><a href="/">HOME</a></p>

  <h1>Members</h1>
  
  <ul>
    {% for x in mymembers %}
      <li><a href="details/{{ x.id }}">{{ x.firstname }} {{ x.lastname }}</a></li>
    {% endfor %}
  </ul>
{% endblock %}

مشاهده در ادیتور

اجرای سرور و تست

سرور را اجرا کن، سپس ریشه سایت را باز کن. آدرس 127.0.0.1:8000/ باید صفحه اصلی را نشان دهد.

python manage.py runserver

مشاهده در ادیتور

جمع بندی سریع

  • یک قالب ساده برای ایندکس بساز.
  • ویو main فقط همان قالب را رندر می کند.
  • مسیر ریشه را به main وصل کن.
  • لینک برگشت در صفحات لیست بگذار.

برای تکمیل مسیر: از قالب مادر استفاده کن، و با لینک به جزئیات تجربه کاربر را بهتر کن. همچنین صفحه ایندکس اصلی لنگر سئویی خوبی است.