创建项目及应用
-
创建项目
执行命令:django-admin startproject 项目名称
-
创建应用
执行命令:django-admin startapp 应用名称
/ 或:python manage startapp 用户名称
修改settings.py
- 在
INSTALLED_APPS
中加入应用名称
在models.py中编写数据模型类
from django.db import models
from django.utils import timezone
from django.contrib.auth.models import User
class 数据模型类名(models.Model):
title = models.CharField(max_length=300)
author = models.ForeignKey(User, related_name="blog_posts")
body = models.TextField()
publish = models.DateTimeField(default=timezone.now)
class Meta:
ordering = ("-publish",)
def __str__(self)
return self.title
执行命令创建数据库
- 执行命令:
python manage.py makemigrations
执行后会在文件夹migrations
中创建一个数据模型,名为0001_initial.py
。 - 执行命令:
python manage.py migrate
此时数据库创建完成。
创建后台管理用户
- 执行命令:
python manage.py createsuperuser
按照提示输入 用户名、邮箱、密码 - 此时可用新创建的用户登录到后台管理,但数据库表不能显示。需进行下一步将数据模型类注册到
admin.py
文件中。
将数据模型类注册到Admin.py中
- 修改
admin.py
文件:
from django.contrib import admin
from .models import 数据模型类名
admin.site.register(数据模型类名)
- 此时刷新页面,即可看到数据表。
修改Admin.py,显示更多内容
- 修改
admin.py
文件,增加代码,写一个类:
from django.contrib import admin
from .models import 数据模型类名
class 类名(admin.ModelAdmin):
list_display = ("title","author","publish") #要显示的字段
list_filter = ("publish","author") #筛选过滤器,在右边出现
search_fields = ('title',"body") #搜索框,在顶部出现
raw_id_fields = ("author")
date_hierarchy = "publish"
ordering = ['publish', 'author']
admin.site.register(数据模型类名)
显示——list记录列表页
此页需要views / urls / templates配合,才能实现。
- visws
编写views.py
文件:
from django.shortcuts import render
from .models import 数据模型类名
def 函数名(request):
blogs = 数据模型类名.objects.all()
return render(request, "模板文件路径", {"blogs":blogs})
- templates
模板文件目录结构
|——templates
|——base.html #公共部分
|——blog
|——list.html
|——show.html
公共部分base.html
:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>{% block title %}{% endblock %}</title>
</head>
<body>
<div class="container">
{% block content %}
{% endblock %}
</div>
</body>
</html>
此文件中定义了块,在Django模板中{% block name %}{% endblock %}
是块标签。此文件是一个基础模板,下面编写views中调用的模板文件。
{% extends "base.html" %}
{% block titles %}blog titles{% endblock %}
{% block content %}
<div class="row text-center vertical-middle-sm">
<h1>我的博客</h1>
</div>
<div class="row">
<div class="col-xs-12 col-md-8">
<ul>
{% for blog in blogs %}
<li><a href="{{ blog.id }}">{{ blog.title }}</a></li>
{% endfor %}
</ul>
</div>
<div class="col-xs-6 col-md-4">
<h2>广告</h2>
<p>www.itdiffer.com</p>
<img width="200px" src="http://www.mrwallpaper.com/wallpapers/Fluffy-Cat.jpg">
</div>
</div>
{% endblock %}
第一行代码表示继承公共基础模板base.html
。
- urls
至此views / templates(即视图函数及模板)两部分已完成。想要通过网页访问,还要进行URL配置。首先配置项目目录下的urls.py
文件:
from django.conf.urls import url, include
from django.contrib import admin
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^blog/', include('blog.urls', namespace='blog', app_name='blog')),
]
通过此文件将http://localhost:8000/blog/
这个请求转到blog应用的urls.py
文件。下面配置./blog/urls.py
文件。
from django.conf.urls import url
from . import views
urlpatterns = [
url(r'^$',views. 函数名, name="blog_title"),
]
网友评论