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按钮, 点击看以看到对应的效果

      RSS和分页_第1张图片
      RSS和分页_第2张图片

      更多功能可以查看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中

      你可能感兴趣的:(RSS和分页)