django的基础配置

一、项目创建

  • 1、使用virtualenvwrapperpipenv创建一个django的虚拟环境,并安装依赖包
  • 2、使用命令创建一个项目

      django-admin startproject [项目名字]
    

二、django中项目文件的配置

这步骤不使用也可以,看个人,本人喜欢将全部的app放在一个目录下,使用第三方的app放在一个目录下

  • 1、项目中创建一个文件夹apps
  • 2、项目中创建一个文件夹extra_apps
  • 3、根据下图方式将上面两个创建的文件夹变成根目录

    根目录

  • 4、在项目的settings.py中添加配置信息

      import os
      import sys
    
      # Build paths inside the project like this: os.path.join(BASE_DIR, ...)
      BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
    
      sys.path.insert(0, os.path.join(BASE_DIR, 'apps'))
      sys.path.insert(0, os.path.join(BASE_DIR, 'extra_apps'))
    
  • 5、使用命令创建app,并直接拖到apps文件夹下

      python manage.py startapp [app名字]
    
  • 6、同理如果是git上下载的第三方源代码就放到extra_apps文件夹下

三、关于视图与url的关联

django中有两种模式来写视图

  • 使用函数的方式(FBV模式)
  • 使用类的方式(CBV模式),本人更喜欢使用类的方式来创建视图

下面介绍使用CBV模式来实现视图

  • 1、创建一个bookapp并且在settings.py中注册
  • 2、将book拖到apps文件夹下
  • 3、在bookapp目录下创建一个urls.py的文件,用于存放当前视图全部的url
  • 4、在视图类中创建几个类

    ```py from django.http import HttpResponse from django.views import View

class BookView(View):
    """
    图书主页视图
    """

    def dispatch(self, request, *args, **kwargs):
         # dispatch这个函数可以不写,查看django源码就是从这个函数开始的
        result = super().dispatch(request, *args, **kwargs)
        return result

    def get(self, request, *args, **kwargs):
        return HttpResponse('图书首页')

    def post(self, request, *args, **kwargs):
        pass


class BookDetailView(View):
    """
    图书详情视图
    """

    def get(self, request, *args, **kwargs):
        # http://localhost:8000/book/1/?name=hello
        print(request.GET.get('name', None))
        print(args)
        # 可以获取到url上定义的参数
        print(kwargs)
        return HttpResponse('图书详情')

    def post(self, request, *args, **kwargs):
        pass
```
  • 5、在本app下的urls.py中定义url信息

      from django.urls import path
      from . import views
    
      app_name = 'book'
    
      urlpatterns = [
          path('', views.BookView.as_view(), name='book_index'),
          path('<int:book_id>/', views.BookDetailView.as_view(), name='book_detail')
      ]
    
  • 6、在主路由中引入当前appurls.py文件

      from django.urls import path, include
    
      urlpatterns = [
          path('', include('home.urls', namespace='home')),
          path('book/', include('book.urls', namespace='book'))
      ]
    

四、配置时区(后面会有专题介绍)

settings.py中配置(以上海时间为配置)大概在109行

TIME_ZONE = 'Asia/Shanghai' # 上海时区
USE_TZ = True

五、配置中文显示(主要是admin中显示)

settings.py中配置

LANGUAGE_CODE = 'zh-hans' # 中文支持,django1.8以后支持;1.8以前是zh-cn

六、数据库的配置

  • 1、默认数据库是使用sqlite
  • 2、如果要使用mysql数据库

      DATABASES = {
          'default': {
              'ENGINE': 'django.db.backends.mysql', # 数据库引擎
              'NAME': 'djangotest', #数据库名称
              'USER': 'root', # 链接数据库的用户名
              'PASSWORD': 'root', # 链接数据库的密码
              'HOST': '127.0.0.1', # mysql服务器的域名和ip地址
              'PORT': 3306, # mysql的一个端口号,默认是3306
          }
      }
    
  • 3、如果你是使用pymysql连接工具必须要在站点__init__.py的文件配置

      import pymysql
      pymysql.install_as_MySQLdb()
    
  • 4、使用mongodb数据库

      DATABASES = {
          'default': {
              'ENGINE': None,
          }
      }
      from mongoengine import connect
      connect('数据库名')
    

七、模板的配置

如果是使用命令方式创建的项目,不会自己创建templates的文件夹,需要手动创建

  • 1、手动创建一个文件夹templates
  • 2、在settings.pyTEMPLATES下面配置模板的使用路径

      'DIRS': [os.path.join(BASE_DIR,'templates' )]
    
  • 3、补充说明'APP_DIRS': True,的认识
    • 这句话的意思是说,如果在templates文件夹下没找到模板会在已经安装的app下继续查找模板,如果没有找到就报错,有就渲染到页面

八、静态文件的配置

在开发过程中可能会使用到的css文件、js文件、img文件我们统一归到静态文件中

  • 1、加载静态的也是一个app,查看app中是否加载该组件

      INSTALLED_APPS = [
          ...
          'django.contrib.staticfiles',
      ]
    
  • 2、说明(静态文件夹的命名是根据settings.pySTATIC_URL一样就可以)

      STATIC_URL = '/static/'
    
  • 3、在settings.py中配置静态文件地址

      STATICFILES_DIRS = (
          'static',
      )
    
  • 4、将static变成django内置标签(这样就不需要在每个html页面头部load staticfiles)

      # 在settings.py文件中配置
      TEMPLATES = [
          {
              ...
              'OPTIONS': {
                  'context_processors': [
                      ...
                  ],
                  'builtins': ['django.templatetags.static']
              },
          },
      ]
    

results matching ""

    No results matching ""