【Django实战一】创建新项目

一、新建Project

bash 复制代码
django-admin startproject 项目名称

二、创建应用

1、创建应用

bash 复制代码
python manage.py startapp 应用名称

应用创建后,项目的根目录下会生成对应应用名称的文件夹

2、注册应用

新创建的应用需要在settings.py中的INSTALLED_APPS中注册该应用

bash 复制代码
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    '项目名称',
]

3、创建视图、定义路由

在新增app下的views.py中添加一个视图函数

言归正传,在view.py下添加一个视图逻辑

python 复制代码
from django.http import JsonResponse
def hello(request):
    data = {
        "code" : 0,
        "msg" : "hello"
    }
    print(data["msg"])
    return JsonResponse(data)

然在urls.py中声明该视图,为其分配请求路径

python 复制代码
from django.contrib import admin
from django.urls import path
from base import views

urlpatterns = [
    path('admin/', admin.site.urls),
    path('hello',views.hello) #这样,当我们向localhost:8000/hello 请求数据时,即可返回hello
]

需要注意的是,以函数形式来编辑逻辑(FBV )与以类形式来编辑逻辑(CBV )时,urls.py上的路径与函数的对应关系是不一样的。

1)使用FBV写:

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

def back_hello(request):
    return HttpResponse('大家好!')
python 复制代码
urlpatterns = [
    url(r'^admin/', admin.site.urls),
]

2)使用CBV写:

python 复制代码
from django.views import View    # 基于类的形式来写试图上的业务逻辑的时候,定义的类需要  继承 django 中的View类  !!!!!!!
class BackHello(View):
    def get(self, request):
        return HttpResponse("get请求的时候!get大家好!")

    def post(self, request):
        return HttpResponse("post请求的时候!post大家好!")
python 复制代码
urlpatterns = [
    url(r'^test/', views.BackHello.as_view()),
]

【本文部分内容参考】

  1. Django框架------基础之视图系统(View.py)
相关推荐
betazhou1 分钟前
SQL server2019 配置故障群集文件共享方式always on高可用群集
数据库·sql server·高可用·always on·文件共享见证
TDengine (老段)6 分钟前
一文讲清 TDengine IDMP 资产数据导入
大数据·数据库·ai·时序数据库·tdengine·涛思数据
O***P57110 分钟前
【Mysql】:如何配置最大连接数?
数据库·mysql
x***381616 分钟前
从MySQL迁移到PostgreSQL的完整指南
数据库·mysql·postgresql
p***233625 分钟前
【MySQL】CAST()在MySQL中的用法以及其他常用的数据类型转换函数
数据库·mysql
O***Z61625 分钟前
【MySQL】表的基本操作
数据库·mysql·oracle
5***g29826 分钟前
MySQL 数据库连接池爆满问题排查与解决
android·数据库·mysql
l***217827 分钟前
MySql-9.1.0安装详细教程(保姆级)
数据库·mysql
v***Y8929 分钟前
SQL 中 COUNT 的用法详解
数据库·sql
I***t71632 分钟前
【MYSQL】聚合查询、分组查询、联合查询
数据库·sql·mysql