【Django篇】--动手实践Django基础知识

一、url视图映射

在url.py中定义两个视图函数,并添加到urlpatterns中用于访问。

python 复制代码
from django.contrib import admin
from django.urls import path
from django.shortcuts import HttpResponse

# 默认的地址为:http://127.0.0.1:8000/

# 如果我想要访问默认地址下的其他内容,可以通过定义视图并将视图进行映射
def index(request):
    return HttpResponse("这是默认页面")

def my_page(request):
    return HttpResponse("我的第一个Django项目,我们一定会顺利毕业滴!")


urlpatterns = [
    path("admin/", admin.site.urls),
    path("", index), # 双引号中为空内容,表示为默认地址
    path("mypage", my_page)  # 自定义url
]

运行后的结果显示:

在Django项目中,如果你希望在开发过程中随时看到代码更改的效果,可以通过设置DEBUGTEMPLATES配置来实现,具体如下:

1、设置DEBUG为True : 在settings.py文件中,将DEBUG设置为True。这样可以确保Django在开发过程中提供详细的错误页面,并且每次代码更改后,页面都会自动刷新以显示最新的代码效果。

python 复制代码
# settings.py

DEBUG = True

2、设置模板的AUTO_RELOAD : 在settings.py文件中,确保TEMPLATES配置中的OPTIONS字典包含了'debug': True,这样可以在开发服务器运行时自动检测模板文件的更改。

python 复制代码
# settings.py

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                ...
            ],
            'debug': True,  # 确保这一行被设置为True
        },
    },
]

二、URL传参

2.1、字符串查询传参

在book/view.py中添加视图:

python 复制代码
from django.shortcuts import render,HttpResponse

# 在url中携带参数
# 1、通过查询字符串(query string) :http://127.0.0.1:8000/book?id=1
# 2、在path中携带:http://127.0.0.1:8000/book/2


def book_detail_query_id(request):
    book_id = request.GET.get('id')
    book_name = request.GET.get('name')
    return HttpResponse(f"我们要查找的图书id是:{book_id},图书名称为:{book_name}")

在url.py中进行视图映射:

python 复制代码
from django.contrib import admin
from django.urls import path
from django.shortcuts import HttpResponse
from book import views
# 默认的地址为:http://127.0.0.1:8000/

# 如果我想要访问默认地址下的其他内容,可以通过定义视图并将视图进行映射
def index(request):
    return HttpResponse("这是默认页面")

def my_page(request):
    return HttpResponse("我的第一个Django项目,我们一定会顺利毕业滴!")


urlpatterns = [
    path("admin/", admin.site.urls),
    path("", index), # 双引号中为空内容,表示为默认地址
    path("mypage", my_page),  # 自定义url
    path("book", views.book_detail_query_id)
]

结果显示:

2.2、path路径传参

在book/view.py中添加视图:

python 复制代码
from django.shortcuts import render,HttpResponse

# 在url中携带参数
# 1、通过查询字符串(query string) :http://127.0.0.1:8000/book?id=1

def book_detail_query_id(request):
    book_id = request.GET.get('id')
    book_name = request.GET.get('name')
    return HttpResponse(f"我们要查找的图书id是:{book_id},图书名称为:{book_name}")

# 2、在path中携带:http://127.0.0.1:8000/book/2
def book_detail_path(request,book_id):
    return HttpResponse(f"您要查找的图书id是:{book_id}")

在url.py中进行视图映射:

python 复制代码
from django.contrib import admin
from django.urls import path
from django.shortcuts import HttpResponse
from book import views
# 默认的地址为:http://127.0.0.1:8000/

# 如果我想要访问默认地址下的其他内容,可以通过定义视图并将视图进行映射
def index(request):
    return HttpResponse("这是默认页面")

def my_page(request):
    return HttpResponse("我的第一个Django项目,我们一定会顺利毕业滴!")


urlpatterns = [
    path("admin/", admin.site.urls),
    path("", index), # 双引号中为空内容,表示为默认地址
    path("mypage", my_page),  # 自定义url
    path("book", views.book_detail_query_id),
    # 在book_id前面添加指定参数类型,如果在浏览器中输入了非整型,会报404错误,并且在视图函数中,book_id就是一个整型,否则是字符串类型
    path("book/<int:book_id>", views.book_detail_path)

]

结果显示:

2.3、path函数

path函数的定义是:path(route,view,name=None,kwargs=None)。

  1. route参数:以下是几种常用的类型:
    • int:匹配任意的零或者正数的整型。到视图函数中就是一个int类型。
    • slug:由英文中的横杠-,或者下划线_连接英文字符或者数字而成的字符串。
    • uuid:匹配uuid字符串
    • path:匹配非空的英文字符串,可以包含斜杠/。
    • str:非空的字符串类型。默认的转换器。但是不能包含斜杠。
  2. view参数:可以为一个视图函数或者类视图.as_view()或者是django.urls.include()函数的返回值。
  3. name参数:这个参数是给这个url取个名字的,这在项目比较大,url比较多的时候用处很大。
相关推荐
xcLeigh4 小时前
Python 项目实战:用 Flask 实现 MySQL 数据库增删改查 API
数据库·python·mysql·flask·教程·python3
威迪斯特4 小时前
Flask:轻量级Web框架的技术本质与工程实践
前端·数据库·后端·python·flask·开发框架·核心架构
xu_yule5 小时前
Redis存储(15)Redis的应用_分布式锁_Lua脚本/Redlock算法
数据库·redis·分布式
一灰灰blog5 小时前
Spring AI中的多轮对话艺术:让大模型主动提问获取明确需求
数据库·人工智能·spring
Nandeska5 小时前
15、基于MySQL的组复制
数据库·mysql
ggabb5 小时前
中国文化速记清单.地名与母亲河.文化名人与经典
sqlite
AllData公司负责人6 小时前
AllData数据中台-数据同步平台【Seatunnel-Web】整库同步MySQL同步Doris能力演示
大数据·数据库·mysql·开源
加油,小猿猿6 小时前
Java开发日志-双数据库事务问题
java·开发语言·数据库
山岚的运维笔记7 小时前
SQL Server笔记 -- 第20章:TRY/CATCH
java·数据库·笔记·sql·microsoft·sqlserver
Gain_chance7 小时前
33-学习笔记尚硅谷数仓搭建-DWS层交易域用户粒度订单表分析及设计代码
数据库·数据仓库·hive·笔记·学习·datagrip