RSS和分页

RSS功能

Django是一个全面型框架, 很多功能都可以直接找到, 对于RSS功能, 可以从其中的高层框架的聚合Feed框架中找到(The syndication feed framework)

上层Feed生成框架可以直接应用Feed类, 我们可以直接继承Feed在其中定义自己的方法

在my_blog/article/views.py中定义类

from django.contrib.syndication.views import Feed  #注意加入import语句

class RSSFeed(Feed) :

title = "RSS feed - article"

link = "feeds/posts/"

description = "RSS feed - blog posts"

def items(self):

return Article.objects.order_by('-date_time')

def item_title(self, item):

return item.title

def item_pubdate(self, item):

return item.add_date

def item_description(self, item):

return item.content

然后在my_blog/my_blog/urls.py中设置对应的url

from django.conf.urls import patterns, include, url

from django.contrib import admin

from article.views import RSSFeed

urlpatterns = patterns('',

# Examples:

# url(r'^$', 'my_blog.views.home', name='home'),

# url(r'^blog/', include('blog.urls')),

url(r'^admin/', include(admin.site.urls)),

url(r'^$', 'article.views.home', name = 'home'),

url(r'^(?P\d+)/$', 'article.views.detail', name='detail'),

url(r'^archives/$', 'article.views.archives', name = 'archives'),

url(r'^aboutme/$', 'article.views.about_me', name = 'about_me'),

url(r'^tag(?P\w+)/$', 'article.views.search_tag', name = 'search_tag'),

url(r'^search/$','article.views.blog_search', name = 'search'),

url(r'^feed/$', RSSFeed(), name = "RSS"),  #新添加的urlconf, 并将name设置为RSS, 方便在模板中使用url

)

下面修改my_blog/templates/base.html, 在其中添加RSS按钮

{% block title %} Andrew Liu Blog {% endblock %}

Andrew Liu Blog

雪忆 - Snow Memory

  • 主页

  • 归档

  • Github

  • Weibo

  • 专题

  • About Me

  • RSS

    {% block content %}

    {% endblock %}

    • About Me
    • Twitter
    • GitHub
    • 保存后, 在浏览器中输入http://127.0.0.1:8000/可以看到新增的RSS按钮, 点击看以看到对应的效果

      更多功能可以查看The syndication feed framework官方文档

      分页功能

      当博客文章较多的时候, 我们并不希望以此在主页上显示全部的博客文章, 而是希望能够每页显示固定的文章数目, 这样既能提高性能, 也能提高美观度, 何乐而不为呢?

      现在这一章节来看看怎么实现分页功能

      首先添加包

      重写home方法

      修改模板

      修改my_blog/my_blog/views.py中的home函数

      fromdjango.core.paginatorimportPaginator, EmptyPage, PageNotAnInteger#添加包defhome(request):posts = Article.objects.all()#获取全部的Article对象paginator = Paginator(posts,2)#每页显示两个page = request.GET.get('page')try:        post_list = paginator.page(page)exceptPageNotAnInteger :        post_list = paginator.page(1)exceptEmptyPage :        post_list = paginator.paginator(paginator.num_pages)returnrender(request,'home.html', {'post_list': post_list})

      修改my_blog/templates下的home.html

      {% extends "base.html" %}{% load custom_markdown %}{% block content %}{% for post in post_list %}{{ post.title }}Time:{{ post.date_time |date:"Y M d"}}{{ post.category|title }}

      {{ post.content|custom_markdown|truncatewords:10 }}

      Read More >>>{% endfor %}    {% if post_list.object_list and post_list.paginator.num_pages > 1 %}
      {% if post_list.has_previous %}
    • 上一页
    • {% endif %}      {% if post_list.has_next %}
    • 下一页
    • {% endif %}
      {% endif %}{% endblock %}

      我设置的是每页显示两篇博文, 可以修改成其他数值

      更多细节可以查看pagination官方文档

      保存后, 在浏览器中输入http://127.0.0.1:8000/可以看到新增的下一页按钮(博客文章要多加几篇), 点击看以看到对应的效果

      到目前为止, 博客的基本功能都实现了, 下一篇我们将讲到怎么在云端进行部署

      最后我们把整个blog更新到github仓库中

      $  git add .  #添加全部更新到暂存区

      $  git commit -m "rss and paginator"  #提交到git

      [master b53356b] rss and paginator

      2 files changed, 24 insertions(+), 1 deletion(-)

      $  git push  #提交到github中

      最后编辑于
      ©著作权归作者所有,转载或内容合作请联系作者
      • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
        沈念sama阅读 159,015评论 4 362
      • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
        沈念sama阅读 67,262评论 1 292
      • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
        开封第一讲书人阅读 108,727评论 0 243
      • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
        开封第一讲书人阅读 43,986评论 0 205
      • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
        茶点故事阅读 52,363评论 3 287
      • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
        开封第一讲书人阅读 40,610评论 1 219
      • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
        沈念sama阅读 31,871评论 2 312
      • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
        开封第一讲书人阅读 30,582评论 0 198
      • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
        沈念sama阅读 34,297评论 1 242
      • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
        茶点故事阅读 30,551评论 2 246
      • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
        茶点故事阅读 32,053评论 1 260
      • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
        沈念sama阅读 28,385评论 2 253
      • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
        茶点故事阅读 33,035评论 3 236
      • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
        开封第一讲书人阅读 26,079评论 0 8
      • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
        开封第一讲书人阅读 26,841评论 0 195
      • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
        沈念sama阅读 35,648评论 2 274
      • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
        茶点故事阅读 35,550评论 2 270

      推荐阅读更多精彩内容