django流程梳理(二)-模板设置

1.配置站点(admin后台配置)

暂不配置

2.创建模板目录/项目模板目录

在与myAPP同级的project目录下创建templates文件夹,在templates下面创建myApp文件夹

myApp文件夹里面可以写自己的html代码,如students.html,grades.html
代码如下

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>班级信息</title>
</head>
<body>
    <h1>班级信息列表</h1>
    <ul>
        <!--p/-->
        {%for grade in grades%}
        <li>
            <a href="{{grade.id}}">{{grade.gname}}</a>
        </li>
        {%endfor%}
    </ul>

</body>
</html>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>学生信息</title>
</head>
<body>
    <h1>学生信息列表</h1>
    <ul>
        {% for student in students%}
        <li>
            {{student.sname}}--{{student.scontend}}
        </li>
        {%endfor%}
    </ul>
</body>
</html>

3.在settings.py中创建模板路径

主要在 TEMPLATES中
主要查看刚开始的 BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR,'templates')], #后来添加的,参考刚开始的代码
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

4.创建视图文件

在和templates以及project同级别的myApp文件夹,里面的view.py文件中创建视图函数
from django.shortcuts import render
from django.http import HttpResponse

# Create your views here.
#视图对web请求进行回应
#视图就是python的一个函数,在本函数中定义


def index(request):
    return HttpResponse("sunck is a good man ")

def detail(request,num,num2):
    return HttpResponse('detail--%s--%s'%(num,num2))
def detail2(request,num):
    return HttpResponse('%s-----------'%num)
from .models import Grades
def grades(request):
    #去模型理取数据
    gradesList =Grades.objects.all()
    #将数据传递给模板,模板渲染页面,将渲染好的页面返回给浏览器
    return render(request,'myApp/grades.html',{'grades':gradesList})
from .models import Students
def students(request):
    studentsList = Students.objects.all()
    return render(request,'myApp/students.html',{'students':studentsList})
def gradesStudents(request,num):
    grade =Grades.objects.get(pk=num)
    studentslist = grade.students_set.all()
    return render(request, 'myApp/students.html', {'students': studentslist})

这里的各类函数都是通过project/view.py中的

urlpatterns = [
    url('admin/', admin.site.urls),
    url('^',include('myApp.urls')),
   # url('^(\d+)/$',include('myApp.urls'))
]

来到第一个(层)myApp中的urls.py(和project齐名的)里面的

from django.conf.urls import url
from . import views

urlpatterns = [
    url('^$',views.index),# ^$表示什么也没有,空白
    url('^(\d+)$',views.detail2),
    url('^(\d+)/(\d+)$',views.detail),
    url('^grades/$',views.grades),
    url('^students/$',views.students),
    url('^grades/(\d+)$',views.gradesStudents),
]

5.在project下修改urls.py

from django.contrib import admin
from django.urls import path,include
from django.conf.urls import url

urlpatterns = [
    url('admin/', admin.site.urls),
    url('^',include('myApp.urls')),#这是后来添加的,表示任何链接都会导入到myApp.urls中
   # url('^(\d+)/$',include('myApp.urls'))
]

6.在项目目录下创建urls.py(就是第一层myAPP.py下面的ursl.py)

from django.conf.urls import url
from . import views

urlpatterns = [
    url('^$',views.index),# ^$表示什么也没有,空白
    url('^(\d+)$',views.detail2),
    url('^(\d+)/(\d+)$',views.detail),
    url('^grades/$',views.grades),
    url('^students/$',views.students),
    url('^grades/(\d+)$',views.gradesStudents),
]

自此,运行项目,首页出现sunck is a good man

猜你喜欢

转载自blog.csdn.net/qq_38162763/article/details/81748632