Python 从0开始 一步步基于Django创建项目(6)实现一个简易网站

本文实现一个简易的网站,包含三个网页:

1)主页

2)城市列表页

3)指定城市信息页

城市、城市信息可以通过Admin site通过管理员账户向数据库中录入。

实现本文功能,需要新建的文件一共7个,其名称及路径如下(如果项目根目录是.\snap_gram):

1  .\snap_gram\snap_gram路径下的urls.py文件

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

urlpatterns = [
    path('admin/', admin.site.urls),
    path('',include('city_infos.urls')),
]

在urlpatterns中注册了两个url。第一个是当浏览器输入127.0.0.1:8000/admin/时,导航至Admin Site。第二个是当浏览器输入127.0.0.1:8000时,到文件city_infos.urls中查找url信息。

2  .\snap_gram\city_infos路径下的urls.py文件

该urls.py文件,被上一步的urls.py包含。

from django.urls import path
from .import views

app_name = 'city_infos'
urlpatterns=[
    path('',views.index,name='index'),
    path('cities/',views.cities,name='cities'),
    path('cities/<int:city_id>/',views.city,name='city'),
]

对应本网站的三个网页,在urlpatterns中注册三个url。

(1)当浏览器输入127.0.0.1:8000,调用视图文件views.py中的函数函数index,该url命名为‘index’

(2)当浏览器输入127.0.0.1:8000/cities/,调用视图文件views.py中的函数函数cities,该url命名为‘cities’

(3) 当浏览器输入127.0.0.1:8000/cities/1/,调用视图文件views.py中的函数函数city,该url命名为‘city’。注意此处的1,代表城市ID,会根据点选城市发生变化。

3  .\snap_gram\city_infos路径下的views.py文件

该文件就是上面提到的‘视图文件’。

from django.shortcuts import render
from .models import City

# Create your views here.
def index(request):
    return render(request,'city_infos/index.html')

def cities(request):
    cities = City.objects.order_by('date_added')
    context = {'cities':cities}
    return render(request,'city_infos/cities.html',context)

def city(request,city_id):
    city = City.objects.get(id=city_id)
    entries = city.entry_set.order_by('date_added')
    context = {'city':city,
               'entries':entries}
    return render(request,'city_infos/city.html',context)

(1)函数index,渲染页面index.html

(2)函数cities,渲染页面cities.html,页面所需的数据保存在字典context中。context中的信息,通过语句City.objects.order_by('date_added')从数据库中查询得到,查询结果按date_added排序。

(3)函数city,渲染页面city.html,页面所需的数据保存在字典context中。context中的city信息,通过语句City.objects.get(id=city_id)从数据库中查询得到;congtext中的entries信息,通过语句city.entry_set.order_by('date_added')从数据库中查询得到。

与前两个函数不同之处在于,函数city需要输入参数‘city_id’以获得具体city,从而获得与该city关联的entry信息。该‘city_id’就是urls.py文件中,path('cities/<int:city_id>/',views.city,name='city')语句中的<int:city_id>。

4  .\snap_gram\city_infos\templates\city_infos路径下的base.html文件

该文件是所有网页模板文件的父模板,被其他模板文件继承。

<p>
    <a href="{% url 'city_infos:index'%}">City Info</a>-
    <a href="{% url 'city_infos:cities'%}">Cities</a>
</p>

{% block content %}{% endblock content %}

模板标签{% url 'city_infos:index'%}生成一个URL,该URL与在city_infos/urls.py中定义的名为'index'的URL模式匹配。

City Info链接到这个URL。

5  .\snap_gram\city_infos\templates\city_infos路径下的index.html文件

{% extends "city_infos/base.html" %}

{% block content %}
<p>这是一个关于城市的网站.</p>
{% endblock content %}

该网页模板继承base.html模板,显示一条简单信息。

6  .\snap_gram\city_infos\templates\city_infos路径下的cities.html文件

{% extends "city_infos/base.html" %}

{% block content %}

    <p>Cities</p>

    <ul>
        {% for city in cities %}
            <li>
                <a href="{% url 'city_infos:city' city.id %}">{{ city }}</a>
            </li>
        {% empty %}
            <li>No topics have been added yet.</li>
        {% endfor %}
    </ul>

{% endblock content %}

该模板所需的cities信息,由‘视图文件views.py’中的cities函数提供。

在为每个city生成的url链接中,加入了city.id信息,该信息将传递给views文件中的city函数,用于提取关于城市的具体信息。

7  .\snap_gram\city_infos\templates\city_infos路径下的city.html文件

{% extends 'city_infos/base.html'%}

{% block content %}

    <p>City:{{ city }}</p>

    <p>Infos:</p>
    <ul>
        {% for entry in entries %}
            <li>
                <p>{{ entry.date_added|date:'M d,Y H:i'}}</p>
                <p>{{ entry.info|linebreaks }}</p>
            </li>
        {% empty %}
            <li>该城市下未添加信息。</li>
        {% endfor %}
    </ul>

{% endblock content %}

该模板所需的city、entries信息,由‘视图文件views.py’中的city函数提供。

以上文件编辑完成后,需要进入虚拟环境,并启动Django服务器。

运行效果:

1)主页

2)城市列表页

3)指定城市信息页

  • 35
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 创建Django项目 在命令行中运行以下命令: ``` django-admin startproject project_name ``` 2. 创建应用程序 在命令行中进入项目文件夹并运行以下命令: ``` python manage.py startapp app_name ``` 3. 配置数据库 打开项目文件夹中的settings.py文件,在DATABASES中配置数据库连接信息。 ``` DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'database_name', 'USER': 'database_user', 'PASSWORD': 'database_password', 'HOST': 'localhost', 'PORT': '3306', } } ``` 4. 创建模型 在应用程序文件夹中的models.py文件中定义模型类,如: ``` from django.db import models class User(models.Model): name = models.CharField(max_length=50) email = models.EmailField(max_length=254) password = models.CharField(max_length=50) created_at = models.DateTimeField(auto_now_add=True) updated_at = models.DateTimeField(auto_now=True) class Meta: db_table = 'user' ``` 5. 创建视图 在应用程序文件夹中的views.py文件中定义视图函数,如: ``` from django.shortcuts import render from .models import User def user_list(request): users = User.objects.all() context = {'users': users} return render(request, 'user_list.html', context) ``` 6. 创建模板 在应用程序文件夹中创建templates文件夹,然后在其中创建HTML模板文件,如: ``` <!DOCTYPE html> <html> <head> <title>User List</title> </head> <body> <h1>User List</h1> <ul> {% for user in users %} <li>{{ user.name }} - {{ user.email }}</li> {% endfor %} </ul> </body> </html> ``` 7. 配置URL 在应用程序文件夹中的urls.py文件中定义URL路由,如: ``` from django.urls import path from .views import user_list urlpatterns = [ path('users/', user_list, name='user_list'), ] ``` 8. 运行Django项目 在命令行中运行以下命令: ``` python manage.py runserver ``` 现在您可以在浏览器中访问http://localhost:8000/users/,查看用户列表。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值