不过世界真是奇妙,如今我们就在猴年马月里!2016年是猴年,按农历计算,6月5日至7月3日是庚午月,正好是“猴年”里的“马月”。那么问题来了:你想不想在猴年马月里学会django呢?css
下面咱们尝试一下,用15行代码结合django写个web程序,来一次django的清爽体验。html
固然,复杂的很呢!!!若是你是跟着官方文档自学过,就会知道,那里有个初级项目是投票网站,分了6部分才讲完。并且若是你是个完彻底全网络编程的初学者,估计过了第3篇才看出个这个项目的样子。并且在学习中,还须要了解django最重要的几方面内容:前端
好比目录结构:python
运行django-admin startproject sitename
后,你会看见sitename文件夹里的四个文件:web
__init__.py settings.py urls.py wsgi.py
再运行python manage.py startapp app01
后,还能够在app01这个app的目录里看出来所谓的MTV架构。chrome
__init__.py admin.py models.py # M,定义各类数据类 templates # T,这是个目录,放html模板的,固然你能够建到项目路径下 views.py # V,根据路由编写的响应各类请求的函数 app.py ...
若是你用过pycharm,新建工程和app后的代码结构如图所示,帅哥作的很好,直接用了。 数据库
固然,这些只是个初级认识,后面还要学习urls处理各类路由,而后怎么定义数据库,怎么先后端传数据,手续很复杂啊!django
可是,你看看人家flask,bottle,分分钟就弄出个hello world
啊!立马就知道大体的框架用法了,django是否是也能这么玩呢?编程
巧了,国外早有django爱好者尝试过django的简单玩法,并且还专门写了本书。今天就抛砖引玉,你们一块儿来玩玩!flask
talk is simple, show me the code!
# -*- coding:utf-8 -*- # a mini Django project import sys from django.conf import settings from django.conf.urls import url from django.http import HttpResponse from django.core.management import execute_from_command_line settings.configure( DEBUG = True, # 调试状态 SECRET_KEY = 'iamasecretkeyhahahaha', # 默认的session须要的key,也为了CSRF ROOT_URLCONF = sys.modules[__name__], # url根目录的配置 ) def home(request): return HttpResponse('a mini django website') # 主页 urlpatterns = [ url(r'^$', home), # 元组类型,默认请求发送到home函数 ] # 启动程序 if __name__ == "__main__": execute_from_command_line(sys.argv)
新建个文件,好比miniWeb.py
,写上这些代码,而后在当前目录下,命令行运行:
>python miniWeb.py runserver
看到这些说明运行成功!
System check identified no issues (0 silenced). June 13, 2016 - 12:23:51 Django version 1.9.7, using settings None Starting development server at http://127.0.0.1:8000/ Quit the server with CTRL-BREAK.
而后用浏览器打开http://localhost:8000/
, wow, look at that! a mini django website
应该已经出如今你的浏览器里!
是否是太简单了? 哈哈! 要的就是这种清爽感受!爽不爽?不算注释的话,也就15行吧。
简单解释一下:这些代码其实就是把一个django标配的settings,view,url,manage几个文件进行了简化与整合,目的在于用最小的代码向你展现django的网页响应过程。 实际也就是把django中的请求生命周期放在一个文件中展现了(咱们这里尚未涉及到model部分)。
流程以下:
1.__name__这行在学习python的时候天天都会用到,就是一个入口函数,在咱们这里就是一个命令行的入口,经过命令行传入
runserver
参数,而后django内部会本身处理;
2.而后咱们打开http://localhost:8000/
,这时候访问的是网站的根目录url,咱们在urlpatterns
里面,为这个指明了要跳转的函数,也就是home
;
3.在home
函数中,会经过Http响应,将页面内容返回给网页前端;
4.因而,咱们看到了页面内容a mini django website
.
只有一行文字啊,这网站太low了!我们给他加点盐,弄个html模板好很差?
仍是直接看代码,关键地方我加了注释:
# -*- coding:utf-8 -*- # a mini Django project import os # 添加模板路径使用 import sys # 保存当前路径 BASE_PATH= os.path.dirname(__file__) from django.conf import settings from django.conf.urls import url # from django.http import HttpResponse # 不须要了 from django.shortcuts import render # 渲染模板,让html中显示后台自定义内容 from django.core.management import execute_from_command_line settings.configure( DEBUG = True, # 调试状态 SECRET_KEY = 'iamasecretkeyhahahaha', # 默认的session须要的key,也为了CSRF ROOT_URLCONF = sys.modules[__name__], # url根目录的配置 TEMPLATE_DIRS = ( os.path.join(BASE_PATH, 'templates'), # 告诉django在当前目录下找templates文件夹,这里仍是元组,记得逗号! ), # 这里记得有逗号,由于setting的配置也是元组 INSTALLED_APPS = ( # 默认的认证和内容的app,须要添加避免传数据的错误 'django.contrib.auth', 'django.contrib.contenttypes', ), ) def home(request): #return HttpResponse('a mini django website') # 主页 data = {'name': 'alex', 'age':18} # 经过模板语言传到页面的数据 print data return render(request, 'index.html', {'data': data}) urlpatterns = [ url(r'^$', home, name='home'), # 元组类型,默认请求发送到home函数 ] # 启动程序 if __name__ == "__main__": execute_from_command_line(sys.argv)
比刚才多了些模板文件的内容,这时候咱们还须要在当前目录下新建一个文件夹,名字就是templates
,而后在里面新建一个html文件,能够像我这个同样,
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> <title>mini django</title> <meta name="description" content=""> <meta name="keywords" content=""> <link href="" rel="stylesheet"> </head> <body> <h1>显示一下data:</h1> {{ data }} <h2>分开输出:</h2> <li>name:`data`.`name`</li> <li>age:`data`.`age`</li> </body> </html>
注意里面用到了一点模板语言,用{{}}表示的,其实就是个上面render
函数最后的参数替换而已。
也就是这句:
return render(request, 'index.html', {'data': data})
注意这里,为了和django默认新建工程一致,我把当前目录名和py文件名字都改为同样的了:miniDjango.
命令行运行: >python miniDjango.py runserver
再次打开浏览器,访问:http://localhost:8000/
, wow, look at that!
显示一下data: {'age': 18, 'name': 'alex'} 分开输出: name:alex age:18
是否是高大上了不少!
甚至,咱们能够直接用Bootstrap的http://v3.bootcss.com/examples/jumbotron/这个模板测试一下。
首先保存这个网页的源码为bt.html文件,放到templates文件夹。
而后添加url和view函数: 以下所示:
def bt(request): data = {'title': 'alex', 'headings':['我是标题1', '我是标题2','我是标题3']} # 经过模板语言传到页面的数据 return render(request, 'bt.html', {'data': data}) urlpatterns = [ url(r'^$', home, name='home'), # 元组类型,默认请求发送到home函数 url(r'^bt/$', bt, name='bt'), # 元组类型,默认请求发送到bt函数 ]
而后访问http://localhost:8000/bt/
就能够看见效果了! 以下图所示:
若是说学习django像作一桌大餐,上面我们讨论的这点内容顶可能是作了个番茄炒蛋。想要学习更多,还须要好好的多加练习,多和一块儿学习的小伙伴讨论,最好再有个名师指点。
人生苦短,我用Python,加油吧,小伙伴们!
今天django的清爽体验到这里就结束了。 欢迎留言一块儿讨论交流!
http://radar.oreilly.com/2014/04/simplifying-django.html
Lightweight Django [book]