1、Django模板

网站如何向客户端返回一个漂亮的页面呢?

  • 漂亮的页面需要htmlcssjs.
  • 可以把这一堆字段串全都写到视图中, 作为HttpResponse()的参数,响应给客户端.

存在的问题 :

  • 视图部分代码臃肿, 耦合度高.
  • 这样定义的字符串是不会出任何效果和错误的.
  • 效果无法及时查看.有错也不容易及时发现.

设想 :

  • 是否可以有一个专门定义前端页面的地方, 效果可以及时展示,错误可以及时发现,并且可以降低模块间耦合度!

解决问题 :模板

  • MVT设计模式中的T,Template

Django中, 将前端的内容定义在模板中, 然后再把模板交给视图调用, 各种漂亮、炫酷的效果就出现了.

模板使用步骤:

  • 1.创建模板
  • 2.设置模板查找路径
  • 3.模板接收视图传入的数据
  • 4.模板处理数据

1.1.创建模板

  • 应用同级目录下创建模板文件夹templates. 文件夹名称固定写法.
  • templates文件夹下, 创建应用同名文件夹. 例, Book
  • 应用同名文件夹下创建网页模板文件. 例 :index.html

1.2.设置模板查找路径

1.3.模板接收视图传入的数据

  • 视图模板加载

1.4.模板处理数据

1.5. 查看模板处理数据成果

总结View-Templates流程

2、展示书籍列表

需求:

实现步骤:

  • 1.创建视图
  • 2.创建模板
  • 3.配置URLconf

2.1.创建视图

  • 查询数据库数据
  • 构造上下文
  • 传递上下文到模板

    from book.models import BookInfo# 定义视图:提供书籍列表信息
    def bookList(request):# 查询数据库书籍列表数据books = BookInfo.objects.all()# 构造上下文context = {'books':books}# 数据交给模板处理,处理完成后通过视图响应给客户端return render(request, 'Book/booklist.html', context)
    

2.2.创建模板

  • 读取上下文数据
  • 构造网页html文档 : 书籍信息以列表样式展示
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>书籍列表信息</title>
</head>
<body><ul>
{% for book in books %}<li>{{book.name}}</li>
{% end for %}
</ul></body>
</html>

2.3.配置URLconf

  • 进入应用中的urls.py文件

    from django.conf.urls import url
    from book.views import index,bookListurlpatterns = [url(r'^$',index),# 匹配书籍列表信息的URL,调用对应的bookList视图url(r'^booklist/$',bookList)
    ]

3、配置和静态文件

3.1 配置文件

3.1.1. BASE_DIR

BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

当前工程的根目录,Django会依此来定位工程内的相关文件,我们也可以使用该参数来构造文件路径。

3.1.2. DEBUG

调试模式,创建工程后初始值为True,即默认工作在调试模式下。

作用:

  • 修改代码文件,程序自动重启

  • Django程序出现异常时,向前端显示详细的错误追踪信息,例如

  • 而非调试模式下,仅返回Server Error (500)

注意:部署线上运行的Django不要运行在调式模式下,记得修改DEBUG=False和ALLOW_HOSTS。

3.1.3. 本地语言与时区

Django支持本地化处理,即显示语言与时区支持本地化。

本地化是将显示的语言、时间等使用本地的习惯,这里的本地化就是进行中国化,中国大陆地区使用简体中文,时区使用亚洲/上海时区,注意这里不使用北京时区表示。

初始化的工程默认语言和时区为英语和UTC标准时区

LANGUAGE_CODE = 'en-us'  # 语言
TIME_ZONE = 'UTC'  # 时区# 时区

将语言和时区修改为中国大陆信息

LANGUAGE_CODE = 'zh-Hans'
TIME_ZONE = 'Asia/Shanghai'

3.2 静态文件

项目中的CSS、图片、js都是静态文件。一般会将静态文件放到一个单独的目录中,以方便管理。在html页面中调用时,也需要指定静态文件的路径,Django中提供了一种解析的方式配置静态文件路径。静态文件可以放在项目根目录下,也可以放在应用的目录下,由于有些静态文件在项目中是通用的,所以推荐放在项目的根目录下,方便管理。

为了提供静态文件,需要配置两个参数:

  • STATICFILES_DIRS存放查找静态文件的目录
  • STATIC_URL访问静态文件的URL前缀

示例

1) 在项目根目录下创建static目录来保存静态文件。

2) 在bookmanager/settings.py中修改静态文件的两个参数为

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

3)此时在static添加的任何静态文件都可以使用网址/static/文件在static中的路径来访问了。

例如,我们向static目录中添加一个index.html文件,在浏览器中就可以使用127.0.0.1:8000/static/index.html来访问。

或者我们在static目录中添加了一个子目录和文件book/detail.html,在浏览器中就可以使用127.0.0.1:8000/static/book/detail.html来访问。

3.3 App应用配置

在每个应用目录中都包含了apps.py文件,用于保存该应用的相关信息。

在创建应用时,Django会向apps.py文件中写入一个该应用的配置类,如

from django.apps import AppConfigclass BookConfig(AppConfig):name = 'book'

我们将此类添加到工程settings.py中的INSTALLED_APPS列表中,表明注册安装具备此配置属性的应用。

  • AppConfig.name属性表示这个配置类是加载到哪个应用的,每个配置类必须包含此属性,默认自动生成。

  • AppConfig.verbose_name属性用于设置该应用的直观可读的名字,此名字在Django提供的Admin管理站点中会显示,如

    from django.apps import AppConfigclass UsersConfig(AppConfig):name = 'book'verbose_name = '图书管理'

Django模板、配置文件、静态文件及案例实现(创建模板、设置模板查找路径、模板接收视图传入的数据、模板处理数据、BASE_DIR、DEBUG、本地语言与时区、App应用配置)相关推荐

  1. django进阶03静态文件和模板

    原创博文地址:django进阶03静态文件和模板 静态文件和模板 静态文件:css,js,image,如果作为纯粹的web应用来看,静态文件的响应并不属于web应用范畴,因为静态文件不涉及业务逻辑,也 ...

  2. Django+Nginx部署静态文件

    通过Nginx部署Django项目时,需要通过Nginx来部署静态文件.具体操作如下: 设置static根目录 在项目的setting.py中"STATIC_URL = '/static/' ...

  3. Django高级管理静态文件和中间件5.1

    管理静态文件 项目中的CSS.图片.js都是静态文件 配置静态文件 在settings 文件中定义静态内容 STATIC_URL = '/static/' STATICFILES_DIRS = [os ...

  4. Django加载静态文件

    方法一: 1.在app目录中创建static 目录,并在该目录下创建存储css,img,js的子目录. 2.在相应的目录下创建相对应的静态文件. static/css/mystyle.css, sta ...

  5. springboot+vue+element-ui下载excel模板(静态文件)

    前端: html:<div style="margin-top: 20px"><el-button @click="downloadDemo" ...

  6. 【Flask】官方教程(Tutorial)-part2:蓝图-视图、模板、静态文件

    前序文章: 官方教程(Tutorial)-part1:项目布局.应用程序设置.定义和访问数据库 蓝图-视图 视图函数是您为响应应用程序请求而编写的代码.Flask 使用模式将传入的请求 URL 与应该 ...

  7. 014:Django商城项目静态文件修改

    本章知识点 1.商城卖家后台界面分析 2.静态模板 3.Extend和include (需要项目模板请留言- - ) 知识点讲解 1.商城卖家后台界面分析 修改base.html 主页设置Index. ...

  8. 开启tomcat服务后,如何解决浏览器访问不到tomcat中图片或文件的问题,以及如何设置访问图片路径

    对于后端项目上传图片到tomcat服务器上的功能模块,为什么会访问不到图片,并且显式404报错的情况. 我总结了一下两点解决方法: 1. 确认自己在tomcat的配置文件中设置了访问路径对应的文件夹名 ...

  9. 布谷鸟沙盒分析静态文件_“案例沙盒方法”喜提国际商学院协会(AACSB)2019年启发式创新奖...

    国际商学院协会(AACSB)于2019年4月14日至16日在英国爱丁堡召开年会,会上公布了2019年Innovation that Inspire的(启发式创新奖)获奖学校及项目.大会共收到800余个 ...

最新文章

  1. 美团点评数据产品专家冷戈:如何利用数据提高用户体验
  2. POPUP_GET_VALUES_DB_CHECKED’
  3. VS2010安装异常中断后无法安装的解决方法(安装时发生严重错误)
  4. 利用spi发送接收信息c语言,SPI接收发送函数程序
  5. java super extends_Java继承和super的用法
  6. Java讲课笔记02:Java集成开发环境
  7. Java面试之什么是GCRoots,能做什么?
  8. java解析apache日志_使用Apache Log4j 2解析日志条目
  9. Linux 命令(95)—— test 命令
  10. (Sublime Text 3)自动跳转到MATLAB运行程序
  11. fetch_lfw_people相关
  12. 计算机科学与技术(密码学)是什么意思,应用密码学
  13. 计算摄影——自动构图
  14. 《IT时代周刊》:雅虎兵败中国
  15. 阿里倡导成立“罗汉堂”, 6名诺贝尔奖得主加入
  16. SparkStreaming可视化之Wisp
  17. ADB 自动补全 及 offline 解决方法
  18. matlab改变图像像素吗,在图像中随机更改像素值程序——matlab
  19. heigh,clientHeight , scrollHeight , offsetHeight介绍
  20. java gravity_Android属性gravity与layout_gravity的区别

热门文章

  1. 十年沉浮,用Python看创业公司消亡史
  2. 深度研究自然梯度优化,从入门到放弃 | Deep Reading
  3. Java 11 正式发布!
  4. 复旦肖仰华:领域知识图谱落地实践中的问题与对策
  5. 如何优雅地用TensorFlow预测时间序列:TFTS库详细教程
  6. 面试官:有了 for 循环 为什么还要 forEach ?
  7. 3行代码写出8个接口,开挂了?
  8. 单点登录系统用 8 张漫画就解释了
  9. 还在写大量 if 来判断?试试用一个规则执行器来替代它
  10. 讲真,下次打死我也不敢随便改serialVersionUID了