Views
视图views 用于处理应用的具体逻辑,也就是MTV里的V了。
假设我有一个blog,且要在article 的app 下,我要对views.py 进行代码的编写,我先要思考我的article 需要哪些功能,之后再考虑如何实现,简单的文章展示一般需要翻页,文章展示这2个功能,那就根据这3个功能先做吧.
常见的view的架构还是基于function-based-view的,相比之下比较简单,但当业务逻辑多了,且代码复用的情况也同时增多的情况下,我觉得class-based-view 会比较适合,毕竟python是一门面向对象的语言么,这个之后再说,先用函数方式实现一点功能吧。
翻页功能,django 有个组件叫做pagination ,非常适合干这个事情,但是我叛逆,不用,于是自己写吧,同样以库的形式写在libs 下面:
#! /usr/bin/python
#-*- coding: utf-8 -*-
from db_conn import DB_Conn
from django.shortcuts import render,render_to_response
from django.http import HttpResponse
def turn_page(request,sqla,sqlb):
global remainpost
dbconn,dbcursor = DB_Conn()
dbcursor.execute(sqla)
allcounts = dbcursor.fetchall()[0][0]
per_page = 5
allpage = allcounts / per_page
remainpost = allcounts % per_page
if remainpost > 0:
allpage += 1
try:
curpage = int(request.GET.get('curpage', '1'))
pagetype = str(request.GET.get('pagetype', ''))
except ValueError:
curpage=1
allpage=1
pagetype=''
if pagetype=="next":
curpage += 1
elif pagetype=="last":
curpage -=1
start = (curpage - 1) * per_page
lim_sql = sqlb + " limit " + str(start) + "," + str(per_page)
dbcursor.execute(lim_sql)
post = dbcursor.fetchall()
return (allpage,post,curpage)
大致意思就是先计算出总量,然后根据每页多少个标题算出需要多少页,然后根据url 传值来判断是下一页还是上一页。
然后在views 中调用这个库:
#-*- coding: utf-8 -*-
from django.shortcuts import render,render_to_response
from django.http import HttpResponse
from libs.db_conn import DB_Conn
from libs.pageturn import turn_page
from django.template import RequestContext
# Create your views here.
def article_home(request):
dbconn,dbcursor = DB_Conn()
sqla = "select count(*) from blog_article"
sqlb = "select * from blog_article"
allpage,post,curpage = turn_page(request,sqla,sqlb)
return render_to_response('index.html',{'tag':tag,'allpage':allpage,'post':post,'curpage':curpage},context_instance=RequestContext(request))
然后在APP目录下建立templates ,创建对应的index.html,(其实我觉得应该是先建立templates 模版,在根据模版的需要搞视图= = 网上教程既然都是先视图,那就先弄视图吧。)