DJANGO-天天生鲜项目从0到1-001-环境框架搭建

一、开发环境搭建

linux虚拟机环境:CentOS7

1.使用Anaconda管理环境,创建新的开发环境:

conda create -n dailyfresh

2.切换至开发环境:

source activate dailyfresh

3.安装package(都是用conda默认的最新版本,python-3.8.2,django-3.0.3):

conda install python
conda install django
conda install mysqlclient

二、搭建项目框架

1.cd至项目目录,创建项目

django-admin startproject dailyfresh

2.cd至dailyfresh根目录,创建各个应用,并配置url

python manager.py startapp user
python manager.py startapp goods
python manager.py startapp cart
python manager.py startapp order

并创建apps目录,将各个应用移动至apps目录下,并在apps下创建__init__.py文件,让该目录表示为一个package

mkdir apps
mv {user,goods,cart,order} apps
cd apps
touch __init__.py

3.创建templates目录,在其目录下在创建各个应用子目录

mkdir -p templates/{goods,user,cart,order}

以上目录结构如下:

 

4.编辑settings.py

4.1 设置apps路径

因为在各个app前添加了一个父级apps目录,所以注册应用和配置url等指定app路径时需要多加一层apps/,为了避免多这一步的麻烦,需要再settings中将apps的路径也添加至根目录下

import sys
sys.path.insert(0, os.path.join(BASE_DIR, 'apps'))

4.2 设置 ALLOWED_HOSTS

LOCAL_IP = '192.168.183.129' #本机IP地址,运行ifconfig查看
ALLOWED_HOSTS = [LOCAL_IP, ]

4.3 添加apps

 4.4 设置TEMPLATES和STATICFILES_DIRS

STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]

4.5 设置数据库

 4.6 设置本地化

5. 启动项目

pyr 为设置的别名:alias pyr='python manage.py runserver 0:8000'

 主机访问成功

 6. 创建模型类

6.0 创建模型基类 BaseModel

对于所有模型表中的公共字段,可以创建一个模型基类,在此类中定义公共字段,让其他模型继承此类

cd项目根目录

mkdir db
cd db
touch __init__.py base_model.py

编辑base_model.py,注意最后Meta中需要制定该类是一个抽象类(abstract = True),才能被其他类继承

6.1 使用django自带的用户模型抽象类

使用django自带的用户模型抽象类,其已包含用户名、密码、邮箱、是否失效等属性,如果有自己额外需要添加的字段,直接在类中添加即可

6.1.1.导入django用户抽象类

from django.contrib.auth.models import AbstractUser

6.1.2.创建用户模型类,继承 AbstractUser和前面定义的 BaseModel

6.1.3.设置settings.py文件,让django认证系统使用我们定义的用户模型类User,这样就能将django创建的用户插入只我们定义的表中,而不是使用其原自带的表(auth_user)

AUTH_USER_MODEL = 'user.User' #django认证系统使用的模型类

若没配置,则runserver时会爆如下错误:

Add or change a related_name argument to the definition for 'User.groups' or 'User.groups'.

Add or change a related_name argument to the definition for 'User.user_permissions' or 'User.user_permissions'.

6.1.4.生成迁移文件

python manage.py makemigrations
python manage.py migrate

若未生成迁移文件,则runserver时会爆如下错误:

raise ValueError("Dependency on app with no migrations: %s" % key[0]) 

ValueError: Dependency on app with no migrations: user

6.2 富文本类型

借助富文本编辑器,网站的编辑人员能够像使用offfice一样编写出漂亮的、所见即所得的页面。此处以tinymce为例,其它富文本编辑器的使用也是类似的。

6.2.1 django-tinymce安装

在虚拟环境中安装包:

pip install django-tinymce

6.2.2 添加设置

编辑 settings.py 文件

添加应用:tinymce

INSTALLED_APPS = (
  ...
  'tinymce',
)

 添加编辑器配置

TINYMCE_DEFAULT_CONFIG = {
  'theme': 'advanced',
  'width': 600,
  'height': 400,
}

编辑项目级的urls文件

urlpatterns = [
  ...
  path('tinymce', include('tinymce.urls')), # 富文本类型
]

 6.2.3 编辑model.py文件,并进行迁移

from tinymce.models import HTMLField
detail = HTMLField(blank=True, verbose_name='商品详情')

至此,去Admin管理页面看应该可以正常显示富文本编辑器,但是我打开看并没有成功,可能是django或者tinymce版本问题,于是换一个富文本编辑器试试看

 

django-ckeditor只需安装和注册app即可使用

6.2.4django-ckeditor安装

$ pip install django-ckeditor

6.2.5 注册应用

INSTALLED_APPS = (
  ...
  'ckeditor', # 富文本编辑器 django-ckeditor
)

6.2.6 模型中使用,并进行迁移

from ckeditor.fields import RichTextField
detail = RichTextField(blank=True, verbose_name='商品详情')

最后效果如下:

 

 
posted @ 2020-04-25 15:24  Alex-GCX  阅读(460)  评论(0编辑  收藏  举报