1 创建Django项目

2 创建app

  python manage.py startapp app名

3 文件配置

  app配置

  静态文件配置

    创建文件夹,下载bootstrap,jquery 归档文件夹,

    文件下载参考:我的网址    

    补充:静态文件可创建在stark(app)下,可以不用配置静态文件?

  数据库配置:默认sqlite3

4 创建关系表

  1 创建表

  2 数据库迁移

    python manage.py makemigrations

    python manage.py migrate

  3 查看数据表:参考Django数据库----在Django中查看数据库

  

4 stark启动:

  1 对stark下apps.py文件进行配置

from django.apps import AppConfig
from django.utils.module_loading import autodiscover_modules class StarkConfig(AppConfig):
name = 'stark'
def ready(self):
autodiscover_modules('admin')

文件配置

  2 单例一个site:单例参考五种单例模式

class StarkModel:
pass # 单例site
class StarkSite(object):
def __init__(self):
"""
_registry:将所有表及所对应的配置类对象统一存放在字典中
"""
self._registry={} # registry:注册
def register(self,model,stark_model=None):
# 判断每张表有没有自定义的配置类对象
if stark_model:
stark_model = StarkModel
self._registry[model] = stark_model(model) site = StarkSite()

实例化site

  3 并且在每个app下创建stark.py文件

5 注册

  在每个app下创建stark.py文件中

  site.register(Book):即将所有表和所对应的模型类放在site._register对应的字典中 

class StarkSite(object):
def __init__(self):
"""
_registry:将所有表及所对应的配置类对象统一存放在字典中
"""
self._registry={} # registry:注册
def register(self,model,stark_model=None):
# 判断每张表有没有自定义的配置类对象
if stark_model:
stark_model = StarkModel
self._registry[model] = stark_model(model)

6 设计url

  多级路由设计:参考Django多级路由设计

  

    # 设计url 1 --二级路由
@property
def urls(self): return self.get_urls(), None, None
# 设计url 2 --二级路由的路由列表
def get_urls(self):
temp = []
# for循环获取每张表对应的url
# config_obj.urls获取每张表对应的增删改查url,及所对应的视图函数,方便视图函数调用
for model,config_obj in self._registry.items():
temp=[
url(r'{}/{}'.format(model._meta.app_label,model._meta.model_form),config_obj.urls)
]
return temp

stark项目流程的更多相关文章

  1. iOS开发项目之一 [ 项目流程]

    项目流程 *人员配置 *客户端(iOS工程师,Android工程师) *前端 h5 *后台人员(php,java,net) *提供接口(请求地址.请求参数,请求方式,接口文档) *UI UE * 效果 ...

  2. ng机器学习视频笔记(十六) ——从图像处理谈机器学习项目流程

    ng机器学习视频笔记(十六) --从图像处理谈机器学习项目流程 (转载请附上本文链接--linhxx) 一.概述 这里简单讨论图像处理的机器学习过程,主要讨论的是机器学习的项目流程.采用的业务示例是O ...

  3. vue框架构建项目流程

    构建项目流程: 1.全局查询:node -v 2.全局初始化:npm install --global vue-cli 3.模块化工程:vue init webpack myapp--->y,n ...

  4. 在IDEA中构建Tomcat项目流程

    在IDEA中构建Web项目流程 打开你的IDEA,跟着我走! 第一步:新建项目 第二步:找到Artifacts 点击绿色的+号,如图所示,点一下 这一步很关键,目的是设置输出格式为war包,如果你的项 ...

  5. Atitit 项目管理 提升开发效率的项目流程方法模型 哑铃型  橄榄型 直板型

    Atitit 项目管理 提升开发效率的项目流程方法模型 哑铃型  橄榄型 直板型 项目主体三个部分 ui界面,中间层,数据库 按照不同的比重可以分为一下三个模型  哑铃型  橄榄型 直板型 哑铃型 开 ...

  6. Vue 简单的总结四(项目流程,DIY脚手架、vue-cli的使用)

    项目流程 1.下载 cdn 2.引包 vue-router依赖vue vue-router.js 3.如果是模块化机制 Vue.use(vue-router) 4.创建示例 let Home = {/ ...

  7. django搭建简单开发项目流程(一)

    1 搭建环境 sudo apt-get install python3-pip 安装pip3 sudo pip3 install virtualenv 安装虚拟环境 virtualenv -p pyt ...

  8. BBS+Blog项目流程及补充知识点

    项目流程: 1. 产品需求 (1)基于用户认证组件和Ajax实现登陆验证(图片验证码) (2)基于forms组件和Ajax实现注册功能 (3)设计系统首页(文章列表渲染) (4)设计个人站点页面 (5 ...

  9. gulp创建完整的项目流程

    所有的环境都是在 node 安装好的基础上执行的. node -v 查看node的安装情况.npm -v查看npm 的安装情况. gulp自动化构建常用参数 1.src 读取文件或者文件夹 2.des ...

随机推荐

  1. STM32之ADC实例(基于DMA方式)

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/zouleideboke/article/details/75112224 ADC简介: ADC(An ...

  2. Html5+Mui前端框架,开发记录(三):七牛云 上传图片

    1.Html界面: <div id="container"> <label>凭证:</label> <div id="uploa ...

  3. JS 长按 移动端

    实质上,长按的时间不应该过长,因为这有可能与手机系统的部分长按手势产生冲突,但也不宜过短,因为长按时间过短与点击没有任何区别, 理论上,判断长按结束,在手机端上仅设置mouseup动作就可以, < ...

  4. java 框架-消息队列ActiveMQ

    https://www.jianshu.com/p/ecdc6eab554c ActiveMQ从入门到精通(一) 22017.03.11 21:40:42字数 2650阅读 57286 这是关于消息中 ...

  5. vue 2.0 + 如何实现加入购物车,小球飞入的动画

    github源码地址:https://github.com/13476075014/node-vue/tree/master/mynodeproject/13.sell/sell 在移动端经常会有加入 ...

  6. 如何用SAP WebIDE的Fiori创建向导基于ABAP OData service快速创建UI5应用

    如果我们手上已经有可以正常工作的OData服务,无论位于ABAP on-premise系统还是public上的internet OData service,都可以用SAP WebIDE里的Fiori创 ...

  7. Windows工作原理

    Windows工作原理中心思想 Windows工作原理的中心思想就是“动态链接”概念.Windows自身带有一大套函数,应用程序就是通过调用这些函数来实现它的用户界面和在屏幕上显示文本与图形的.这些函 ...

  8. KVM虚拟机高级设置——10 快照、克隆、替换磁盘

    查看虚拟机磁盘文件 [root@CentOS2 ~]# cd /var/lib/libvirt/images/ [root@CentOS2 images]# ll -h total 13G -rw-r ...

  9. mount命令解析

    可以参考两位大神的理解 Linux mount 命令 Linux的mount命令详解

  10. 深度学习—从LeNet到DenseNet

    CNN从90年代的LeNet开始,21世纪初沉寂了10年,直到12年AlexNet开始又再焕发第二春,从ZF Net到VGG,GoogLeNet再到ResNet和最近的DenseNet,网络越来越深, ...