通过简单示例,使用django完成基本流程的开发,学习django的主要的知识点,在后续课程中会逐个知识点进行深入讲解
  以“图书-英雄”管理为示例
  环境搭建
  定义模型
  使用后台管理
  编写视图
  定义模板
  这里简单的演示完成一个 django 大概流程,后面会有详细解释
  以下使用的是 ubuntu 系统
  在生产环境中,有的时候,我们开发的项目可能用的是几个不同的 环境,所以通常我们会创建虚拟环境,在虚拟环境中安装我们需要的 配置,这里从配置虚拟环境开始
  创建:mkvirtualenv [虚拟环境名称]
  删除:rmvirtualenv [虚拟环境名称]
  进入:workon [虚拟环境名称]
  退出:deactivate
  所有的虚拟环境,都位于/home/.virtualenvs目录下
  进入虚拟环境前的提示:
  进入虚拟环境后的提示:
  查看当前的所有虚拟环境:workon [两次tab键]
  查看虚拟环境中已经安装的包
  建议安装1.8.2版本,这是一个稳定性高、使用广、文档多的版本
  查看版本:进入python shell,运行如下代码
  说明:使用pip install django命令进行安装时,会自动删除旧版本,再安装新版本
  命令django-admin startproject test1
  进入test1目录,目录结构如下图:
  manage.py:一个命令行工具,可以使你用多种方式对Django项目进行交互
  内层的目录:项目的真正的Python包
  _init _.py:一个空文件,它告诉Python这个目录应该被看做一个Python包
  settings.py:项目的配置
  urls.py:项目的URL声明
  wsgi.py:项目与WSGI兼容的Web服务器入口
  表格需求:略
  本示例完成“图书-英雄”信息的维护,需要存储两种数据:图书、英雄
  图书表结构设计:
  表名:BookInfo
  图书名称:btitle
  图书发布时间:bpub_date
  英雄表结构设计:
  表名:HeroInfo
  英雄姓名:hname
  英雄性别:hgender
  英雄简介:hcontent
  所属图书:hbook
  图书-英雄的关系为一对多
  在settings.py文件中,通过DATABASES项进行数据库设置
  django支持的数据库包括:sqlite、mysql等主流数据库
  Django默认使用SQLite数据库
  应用的目录结构如下图
  有一个数据表,就有一个模型类与之对应
  打开models.py文件,定义模型类
  引入包from django.db import models
  模型类继承自models.Model类
  说明:不需要定义主键列,在生成时会自动添加,并且值为自动增长
  当输出对象时,会调用对象的str方法(也就是说,你可以定义一个 str 方法,在里面写入自己想要输出的内容)
  激活模型:编辑settings.py文件,将booktest应用加入到installed_apps中
  生成迁移文件:根据模型类生成sql语句
  迁移文件被生成到应用的migrations目录
  执行迁移:执行sql语句生成数据表
  引入需要的包:
  查询所有图书信息:
  新建图书信息:
  查找图书信息:
  修改图书信息:
  删除图书信息:
  对于HeroInfo可以按照上面的操作方式进行
  添加,注意添加关联对象
  运行如下命令可以开启服务器
  可以不写ip,默认端口为8000
  这是一个纯python编写的轻量级web服务器,仅在开发阶段使用
  服务器成功启动后,提示如下信息
  默认端口是8000,可以修改端口
  打开浏览器,输入网址“127.0.0.1:8000”可以打开默认页面
  如果修改文件不需要重启服务器,如果增删文件需要重启服务器
  通过ctrl+c停止服务器
  站点分为“内容发布”和“公共访问”两部分
  “内容发布”的部分负责添加、修改、删除内容,开发这些重复的功能是一件单调乏味、缺乏创造力的工作。为此,Django会根据定义的模型类完全自动地生成管理模块
  使用django的管理
  创建一个管理员用户
  启动服务器,通过“127.0.0.1:8000/admin”访问,输入上面创建的用户名、密码完成登录
  进入管理站点,默认可以对groups、users进行管理
  管理界面本地化
  编辑settings.py文件,设置编码、时区
  向admin注册booktest的模型
  打开booktest/admin.py文件,注册模型
  刷新管理页面,可以对BookInfo的数据进行增删改查操作
  问题:如果在str方法中返回中文,在修改和添加时会报ascii的错误
  解决:在str()方法中,将字符串末尾添加“。encode('utf-8')”
  自定义管理页面
  Django提供了admin.ModelAdmin类
  通过定义ModelAdmin的子类,来定义模型在Admin界面的显示方式
  列表页属性
  list_display:显示字段,可以点击列头进行排序
  list_filter:过滤字段,过滤框会出现在右侧
  search_fields:搜索字段,搜索框会出现在上侧
  list_per_page:分页,分页框会出现在下侧
  添加、修改页属性
  fields:属性的先后顺序
  fieldsets:属性分组
  关联对象
  对于HeroInfo模型类,有两种注册方式
  方式一:与BookInfo模型类相同
  方式二:关联注册
  按照BookInfor的注册方式完成HeroInfo的注册
  接下来实现关联注册
  可以将内嵌的方式改为表格
  布尔值的显示
  发布性别的显示不是一个直观的结果,可以使用方法进行封装
  在admin注册中使用gender代替hgender
  在django中,视图对WEB请求进行回应
  视图接收reqeust对象作为第一个参数,包含了请求的信息
  视图就是一个Python函数,被定义在views.py中
  定义完成视图后,需要配置urlconf,否则无法处理请求
  在Django中,定义URLconf包括正则表达式、视图两部分
  Django使用正则表达式匹配请求的URL,一旦匹配成功,则调用应用的视图
  注意:只匹配路径部分,即除去域名、参数后的字符串
  在test1/urls.py插入booktest,使主urlconf连接到booktest.urls模块
  在booktest中的urls.py中添加urlconf
  模板是html页面,可以根据视图中传递的数据填充值
  创建模板的目录如下图:
  修改settings.py文件,设置TEMPLATES的DIRS值
  在模板中访问视图传递的数据
  定义index.html模板
  定义detail.html模板
  在模板中访问对象成员时,都以属性的方式访问,即方法也不能加括号
  编辑views.py文件,在方法中调用模板
  在index.html模板中,超链接是硬编码的,此时的请求地址为“127.0.0.1/1/”
  看如下情况:将urlconf中详细页改为如下,链接就找不到了
  此时的请求地址应该为“127.0.0.1/book/1/”
  问题总结:如果在模板中地址硬编码,将来urlconf修改后,地址将失效
  解决:使用命名的url设置超链接
  修改test1/urls.py文件,在include中设置namespace
  修改booktest/urls.py文件,设置name
  修改index.html模板中的链接
  Django提供了函数Render()简化视图调用模板、构造上下文
  安装配置django运行的环境
  编写模型,使用简单API与数据库交互
  使用django的后台管理中维护数据
  通过视图接收请求,通过模型获取数据,展示出来
  调用模板完成展示
                    	
                    	
                    	  
                    	    
                    	    
                    	    
                    	 
    如果您觉得本文的内容对您的学习有所帮助:
     
                    	
                    	   
                    	   关键字:
jquery