【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)
相关推荐
sunwenjian8867 分钟前
Springboot项目本地连接并操作MySQL数据库
数据库·spring boot·mysql
Navicat中国1 小时前
如何轻松创建存储过程 | Navicat 教程
数据库·存储过程·可视化·navicat
Mr. Cao code1 小时前
MySQL服务器配置与socket连接详解
服务器·数据库·mysql
Yupureki1 小时前
《MySQL数据库基础》1. 数据库基础
c语言·开发语言·数据库·c++·mysql·oracle·github
杰克尼1 小时前
苍穹外卖--day08
java·数据库·spring boot·mybatis·notepad++
xyyaihxl1 小时前
【MySQL】复合查询
数据库·mysql
m0_716667071 小时前
NumPy入门:高性能科学计算的基础
jvm·数据库·python
lierenvip1 小时前
SQL 建表语句详解
java·数据库·sql
zuguangboy1 小时前
【Oracle-无效的参数绑定】DateTimeOffset映射TIMESTAMP WITH LOCAL TIME ZONE踩坑记
数据库·oracle
未来龙皇小蓝2 小时前
【MySQL-索引调优】02:单列索引
数据库·mysql·性能优化