美文网首页
RSS和分页

RSS和分页

作者: 阡陌3536 | 来源:发表于2017-08-30 14:26 被阅读0次

    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中

        相关文章

          网友评论

              本文标题:RSS和分页

              本文链接:https://www.haomeiwen.com/subject/yxutjxtx.html