美文网首页
Django 基础 (二)—创建应用并了解各py文件作用

Django 基础 (二)—创建应用并了解各py文件作用

作者: Yinag | 来源:发表于2017-07-29 22:56 被阅读0次

    最近全国各地全是高温状态,中午睡个觉都是被热醒的,整天晕乎乎的,之前被Django弄得一脸懵逼,各个py文件之间紧密联系。现在,趁着清醒,来说说。



    上次已经讲过怎样创建项目和应用。现在,借着之前已经创建好的应用内容跟大家介绍下。应用名:myblog

    (一)创建第一个简单页面(响应)

    1. 这会儿我们不需要操作什么,只需编辑blog.views,改改(总目录)myblog/urls.py


    • 小知识:
      a、每个响应对应一个函数(),对应一个URL,并且函数必须返回一个响应
      b、函数必须存在一个参数,一般约定为request
      效果:
    1. 配置URL
      编辑urls.py
    • 小知识:
      a、每个URL都以url的形式写出来
      b、url函数放在urlpatterns列表中
      c、url函数有三个参数:URL(正则),对应的方法,名称
      代码:
    from django.conf.urls import url
    from django.contrib import admin
    
    import blog.views as bv
    
    urlpatterns = [
        url(r'^admin/', admin.site.urls),
        url(r'^index/', bv.index)
    ]
    
    1. 第二种URL配置(包含其他url)
      修改根目录;在应用目录新建一个urls.py (可以直接复制根的urls.py到应用下,把多余的内容删掉)并且修改内容
    • 小知识:
      a、在根urls.py中引入include
      b、在APP(应用)目录下创建urls.py 文件,格式与根的urls.py相同,删掉多余的
      c、在根urls.py中url函数的第二个参数改为include('blog.urls')

    代码:
    a、根 urls.py

    from django.conf.urls import url, include
    from django.contrib import admin
    
    urlpatterns = [
        url(r'^admin/', admin.site.urls),
        url(r'^blog/', include('blog.urls')),
    ]
    

    b、应用 urls.py

    from django.conf.urls import url
    from .import views
    
    urlpatterns = [
        url(r'^index/', views.index),
    ]
    

    效果:


    注意事项:
    根urls.py 针对APP配置的URL名称是该APP所有的url的总路径,配置url时注意正则表达式结尾符号$和/

    小结:两种URL配置方法都可以达到相同的效果,但是建议采用第二种,易于维护、管理,同时避免总项目的urlpatterns庞大

    (二)Templates介绍

    1. 什么是templates?
      一个一个使用了Django模板语言(Django Template Language,DTL)的HTML文件。当然,也可以使用第三方模板(jinja2)
    2. 开发第一个Template
      步骤:
      a、在APP(应用)的根目录下创建名叫template的目录(directory)
      b、在该目录下,可以添加我们想要的HTML文件
      c、在views.py中返回render()。render函数,将HTML界面响应给浏览器,render()函数传递一般三个参数(请求对象,HTML文件,后台往前端输送的数据)
      views.py
    from django.shortcuts import render
    
    
    def index(request):
        return render(request, 'index.html')
    
    1. render()函数传递的第三个参数
      render()函数中支持一个dict字典(键值对)类型的参数;
      该字典是后台传递到模板的参数,键为参数名,在模板中使用{{参数名}}来直接使用
      譬如:


    • 小知识:
      a、当一个项目中添加有多个应用时,Django按照INSTALLED_APPS中的添加顺序查找Templates,不同的应用下Templates的html文件名字相同造成冲突
      b、解决办法:在APP的Templates目录下创建以APP名为名称的目录,将html文件放入新创建的目录下

    (三)Models介绍
    1.Models是什么?
    通常,一个Model对应数据库的一张数据表。Django中Models以类的形式表现,它包含了一些基本字段以及数据的一些行为。采用ORM(对象关系映射)实现了对象与数据库之间的映射,隐藏了数据访问的细节,不需要编写任何SQL语句,对类的操作相当于是对数据库的操作。
    2.编写Models步骤
    a、创建类,继承models.Model,该类即是一张数据表
    b、在类中创建字段(类里面的属性)
    models.py

    from django.db import models
    
    
    class Article(models.Model):
        title = models.CharField(max_length=32)
        content = models.TextField(null=True)
    

    3.生成数据表
    现在类已经写好了,就要把类与数据库对应起来。注意,每次修改了models.py文件里面的内容,一定操作一下步骤,才会修改有效不会报错
    a、命令行中manage.py 同级目录,执行python manage.py makemigrations blog(对应app的名称)
    若不写app的名称,则默认该项目下所有应用都生成数据迁移
    b、再执行python manage.py migrate
    c、数据表(迁移文件)的查看
    Django会自动在app/migrations/目录下生成移植文件;执行python manage.py sqlmigrate 应用名 文件的id 查看SQL语句

    pycharm中看到了移植文件0001 查看SQL语句操作
    (四)Admin简介
    什么是Admin?
    Admin是Django自带的一个功能强大的自动化数据管理界面,被授权的用户可直接在Admin中管理数据库,Django提供了许多针对Admin的定制功能。
    1.配置Admin
    创建超级用户:pyhton manage.py createsuperuser进行用户名、邮箱地址、密码的设置 配置Admin
    登录网址:http://127.0.0.1:8000/admin/ 查看admin管理网站 登录时的界面

    改变页面成为中文界面:修改settings.py中的LANGUAGE_CODE = 'en-us'LANGUAGE_CODE = 'zh_Hans'

    1. 配置应用
      在应用下admin.py 文件中引入自身的models模块(或里面的模型类)
      编辑admin.py: admin.site.register(Article)

    admin.py:

    from django.contrib import admin
    from blog.models import Article
    admin.site.register(Article)
    

    配置应用后的界面:

    配置应用后

    配置应用前:

    配置前

    Tips:下次介绍完善页面基本内容操作

    相关文章

      网友评论

          本文标题:Django 基础 (二)—创建应用并了解各py文件作用

          本文链接:https://www.haomeiwen.com/subject/bckclxtx.html