python Web开发框架-Django (1)

以前用web.py(另外一款轻量级web开发框架)做一个监控管理平台,没有做特别的记录就不好拾起来。最近做一个日志聚合系统,使用的是django,这次就记下来,方便查询。

Django是一个高效的web开发框架,上手容易,便于调试和发布。

设计模式

它的设计遵循经典的web设计架构-MVC(Model-view-controller),一个应用分为四部分:

  • models.py:文件主要用一个 Python 类来描述数据表。 称为 模型(model) 。本文不对model做详细介绍,数据库的存取是单装了mysql,自己做的dao。
  • views.py:文件包含了页面的业务逻辑。是模板和模型间的桥梁,接收前端url请求,进行业务逻辑实现,最后返回数据(结果或模板)。
  • urls.py:一个配置文件,用于映射 URL到视图。
  • xxx.html: html 模板,它描述了页面设计,支持简单的模板语言。

环境准备

python & django,本文使用的是python-2.7.9,django-1.7.6

模板语言

在html中使用模板语言定义页面框架和内容,后台由模板引擎渲染成完整的html。{% %}用于逻辑控制,{{}}用于变量引用

模板间关系

  • include:{% include 'nav.html' %},引入布局单元
  • 模板继承:定义一个基础模板(定义页面框架),由子模板来继承(填充个性化页面子块)。基础模板使用block标签-{% block %},每个block下的这一块内容将有可能被子模板覆盖。子模板用extends标签来继承基础模板{% extends "base.html" %}。
//base.html
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN">
<html lang="en">
<head>
<title><strong>{% block</strong> title <strong>%}{% endblock %}<</strong>/title>
</head>
<body>
<h1>My helpful timestamp site</h1>
{% block content %}{% endblock %}
{% block footer %}
<hr>
<p>Thanks for visiting my site.</p>
{% endblock %}
</body>
</html>
//子模板 current.html
<strong>{% extends "base.html" %} {% block title %}</strong>The current time<strong>{% endblock %}</strong> {% block content %}
<p>It is now {{ current_date }}.</p>{% endblock %}

基本控制标签

  • {% if %} {% else %} {% endif %}:支持and/or/not关键字,不支持and/or组合,不支持用圆括号来组合比较操作,不支持 elif
  • {% for %}{% endfor %}:循环语法是 for X in Y
  • {% ifequal %}{% endifequal %}或者ifnotequal:只有模板变量,字符串,整数和小数可以作为 {% ifequal %} 标签的参数
  • {{var|op}}:模板过滤器,在变量被显示前修改它的值。op有lower/upper/length/join等操作

补充:python中空列表、空元组、空字典、空字符串、0、None对象、False对象代表布尔值假,其余都是真布尔值。

相关技术点

前端页面:HTML、JavaScript、HTML DOM、JQuery、ajax、JSON

后端逻辑:python

页面模板:建议网上找基于bootstrap的网页模板

实例流程

项目创建

django-admin.py startproject tulip

获得如下的目录,manage.py/__init__.py/wsgi.py不需要修改,另外手动创建static目录用于保存js/css,创建templates用于保存html模板,创建lib用于保存依赖库

tulip/
manage.py
tulip/
__init__.py
settings.py
urls.py
wsgi.py
static/
templates/

配置修改

我们新增templates/static目录,在模板中想要正确引用,需要修改下django settings.py

BASE_DIR = os.path.dirname(__file__)
STATIC_URL = '/static/'
STATICFILES_DIRS = (
os.path.join(BASE_DIR,'static').replace('\\','/'),
)
TEMPLATE_DIRS = (
os.path.join(BASE_DIR, 'templates').replace('\\','/'),
)
TIME_ZONE = 'Asia/Shanghai' #语言指定为中文

在页面中就可以如下引用js或者css

<script src="/static/js/jquery-1.10.2.js"></script>
<link href="/static/css/bootstrap.css" rel="stylesheet">

python返回html也可以直接写html文件名,不用加templates

逻辑实现

写页面

//search.html
<select id="servicename" class="form-control" onchange="getServiceInfo()">
<option value="">应用服务</option>
{% for service in servicenames %}
<option>{{ service }}</option>
{% endfor %}
</select>

配置urls.py

from django.conf.urls import patterns, include, url
urlpatterns = patterns('tulip',//tulip是模块名,作为后续映射路径的共同前缀
url(r'^$', 'searchText.index'),
)

视图逻辑

//searchText.py
from django.shortcuts import render_to_response
from django.http import HttpResponse
def index(request):
dao = TulipDao()
servicenames = dao.getServicenames()
return render_to_response('search.html', locals())
#或者return render_to_response('search.html',{'servicenames':servicenames})
#locals()返回的字典包含所有局部变量的名称与值的映射

启动应用

python manage.py runserver 0.0.0.0:8000 //0.0.0.0允许任意非本地连接,不指定ip则仅监听本地连接

文章太长了,再分一篇吧,下一篇记录一些技巧和参考资料

上一篇:mailto实现将用户在网页中输入的内容传递到本地邮件客户端


下一篇:oracle表分区【转】