基本的な使用ジャンゴ

基本的な使用ジャンゴ

Djangoのインストール
pip install django
Djangoプロジェクトを作成します。
django-admin.py startproject 项目名称
Djangoアプリケーションを作成します。
python manage.py startapp app名称
Djangoプロジェクトが開始しました
python manage.py runserver IP:PORT
ディスプレイに現在の時刻を追加
  1. view.pyファイルを変更します
from django.shortcuts import render,HttpResponse
import datetime

def timer(request):
    now = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
    return HttpResponse(now)
  1. ファイルを変更しurls.py
from django.contrib import admin
from django.urls import path
from vedio import views

urlpatterns = [
    path('admin/', admin.site.urls),
    path('timer/', views.timer),
]
HTMLページへのジャンプ
  1. templatesディレクトリにHTMLファイルを追加します。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
登录
</body>
</html>
  1. ページへのview.pyジャンプで
from django.shortcuts import render,HttpResponse

def login(request):
    return render(request, "login.html")
  1. ファイルを変更しurls.py
from django.contrib import admin
from django.urls import path
from vedio import views

urlpatterns = [
    path('admin/', admin.site.urls),
    path('login/', views.login),
]

提出されたデータのページを取得します。

  1. templatesディレクトリにHTMLファイルを追加します。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<form action="http://127.0.0.1:8000/auth/" method="post">
    {% csrf_token %}
    <input type="text" name="name">
    <input type="password" name="password">
    <input type="submit">
</form>
</body>
</html>
  1. ページへのview.pyジャンプで
from django.shortcuts import render,HttpResponse

def login(request):
    return render(request, "login.html")

def auth(request):
    print(request.POST)
    print(request.POST.get("name"))
    print(request.POST.get("password"))
    return HttpResponse("OK")
  1. ファイルを変更しurls.py
from django.contrib import admin
from django.urls import path
from vedio import views

urlpatterns = [
    path('admin/', admin.site.urls),
    path('login/', views.login),
    path('auth/', views.auth),
]

PS:データを返すする試みが存在しない場合setting.pyにコメントすることができます「django.middleware.csrf.CsrfViewMiddleware」

URLの値は、上を通過取得します

  1. ファイルを変更しurls.py
from django.contrib import admin
from django.urls import path
from django.conf.urls import url
from vedio import views

urlpatterns = [
    path('admin/', admin.site.urls),
    url(r"^login/(\w*)$", views.login),
]
  1. view.pyファイルを変更します
from django.shortcuts import render,HttpResponse

def login(request, name):
    return HttpResponse(name)
有名なグループ化
  1. ファイルを変更しurls.py
from django.contrib import admin
from django.urls import path
from django.conf.urls import url
from vedio import views

urlpatterns = [
    path('admin/', admin.site.urls),
    url(r"^login/(?P<分组名称>\w*)$", views.login),
]
  1. view.pyファイルを変更します
from django.shortcuts import render,HttpResponse

def login(request, 分组名称):
    return HttpResponse(分组名称)
配布
  1. ファイルを変更しurls.py
from django.contrib import admin
from django.urls import path
from django.conf.urls import url, include

urlpatterns = [
    path('admin/', admin.site.urls),
    url(r'vedio/', include('vedio.urls')),
]
  1. Vedioのアプリケーションで新しいファイルを作成します。urls.py
from django.contrib import admin
from django.urls import path
from django.conf.urls import url, include
from vedio import views

urlpatterns = [
    path('admin/', admin.site.urls),
    url(r'^login/', views.login),
]
逆引き参照
  1. ファイルを変更しurls.py
from django.contrib import admin
from django.urls import path
from django.conf.urls import url
from vedio import views

urlpatterns = [
    path('admin/', admin.site.urls),
    url(r"^login/(\w*)$", views.login, name='login'),
]
  1. login.htmlにファイルを変更します
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<form action="http://127.0.0.1:8000/{% url 'login' %}" method="post">
    <input type="text" name="name">
    <input type="password" name="password">
    <input type="submit">
</form>
</body>
</html>
基本的なリクエストとレスポンスオブジェクトを使用
  1. ファイルを変更するのurls.py
from django.contrib import admin
from django.urls import path
from django.conf.urls import url
from vedio import views

urlpatterns = [
    path('admin/', admin.site.urls),
    url(r"^login/$", views.login, name='login'),
]
  1. view.pyファイルを変更します
from django.shortcuts import render,HttpResponse,redirect

def login(request):
    """
    request 中的属性和方法
    """
    print(request.method)  # 请求方式
    print(request.path)  # 请求路劲
    print(request.POST)  # POST 请求的数据
    print(request.GET)  # GET 请求的数据
    print(request.META)  # 请求头
    print(request.get_full_path())  # 请求的完整路径
    print(request.is_ajax())  # 判断请求是否是 Ajax请求

    """
    response 的三种形式
        HttpResponse()
        render()
        redirect() 重定向
    """
    # return HttpResponse('OK')
    # return render(request, 'login.html')
    # return redirect('login.html')

    name = ['GetcharZp', 'GetcharMcx']
    # return render(request, 'login.html', locals())
    import datetime
    now = datetime.datetime.now()
    return render(request, 'login.html', {"name": name, "now": now})
  1. ファイルを変更login.htmlと
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
返回一条数据:
<!-- 深度查询 句点符 -->
{{ name.0 }}

<br>将数据以循环的形式输出:
<ul>
{% for foo in name %}
    <li> {{ forloop.late }} {{ forloop.counter }} {{ foo }}</li>
{% endfor %}
    

<br>当前时间(filter)
<!-- 
    date 时间过滤器 |date:"Y-m-d"
    default 默认过滤器 |default:"改内容暂时还木有"
    length 长度过滤器 |length
    filesizeformat 文件大小过滤器 |filesizeformat
    slice 切片过滤器 |slice:"1:3"
    truncatechares 字符过滤器 |truncatechares:9
    truncatewords 单词过滤器 |truncatewords:7
    safe 标识标签不用转义 |safe
-->
{{ now|date:"Y-m-d" }}
</ul>
</body>
</html>
テンプレートの継承
  1. ファイルを変更するのurls.py
from django.contrib import admin
from django.urls import path
from vedio import views

urlpatterns = [
    path('admin/', admin.site.urls),
    path('index/', views.index),
]
  1. view.pyファイルを変更します
from django.shortcuts import render,HttpResponse,redirect

def index(request):
    return render(request, "index.html")
  1. index.htmlファイルを変更します。
{% extends 'base.html' %}
{% block content %}
<p>GetcharZp Index</p>
{% endblock %}
  1. 新しいファイルを作成しますbase.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        
        .header {
            width: 100%;
            height: 90px;
            background-color: #65ccff;
        }
    </style>
</head>
<body>
<div class="header"></div>
{% block content %}

{% endblock %}
</body>
</html>

おすすめ

転載: www.cnblogs.com/GetcharZp/p/11627934.html