【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)
相关推荐
青槿吖42 分钟前
第二篇:告别XML臃肿配置!Spring注解式IOC/DI保姆级教程,从入门到真香
xml·java·开发语言·数据库·后端·sql·spring
运维 小白1 小时前
2. 部署mysql服务并监控mysql
数据库·mysql·adb
聪明人2 小时前
macOS安装Redis
数据库·redis·macos
weixin_505154462 小时前
Bowell Studio:重塑工业互联网时代的装配制造与运维检修
运维·数据库·人工智能·制造·数字孪生·3d产品配置器·3d交互展示
sa100272 小时前
淘宝商品详情 API 接口开发实战:item_detail 调用、参数与 Python 示例
linux·数据库·python
小光学长3 小时前
基于ssm的膳食健康管理系统e6whl4q7(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·开发语言·数据库·学习·ssm
一个天蝎座 白勺 程序猿3 小时前
KingbaseES融合数据库:一库多能,企业数据管理新思路
数据库·性能优化·kingbasees·金仓数据库
橘颂TA3 小时前
【MySQL】解锁表的 N 种牵手方式:SQL 连接与子查询漫游(复合查询)
数据库·mysql
数据知道3 小时前
MongoDB基于角色的访问控制(RBAC):精细化权限管理的实用方法
数据库·mongodb
代码派3 小时前
NineData社区版:免费+本地化部署,满足数据库DevOps、数据复制与一致性对比的数据库管理平台
运维·数据库·database·devops·数据库管理工具·ninedata·数据库迁移