(十二)日志列表页

apis.py中添加了Page类用于存储分页信息,用doctest测试成功:

class Page(object):

    '''
    >>> p1 = Page(100, 1)
    >>> p1.page_count
    10
    >>> p1.offset
    0
    >> p1.limit
    10
    >>> p2 = Page(90, 9, 10)
    >>> p2.page_count
    9
    >>> p2.offset
    80
    >> p2.limit
    10
    >>> p3 = Page(91, 10, 10)
    >>> p3.page_count
    10
    >>> p3.offset
    90
    >> p3.limit
    10
    '''
    # 条目总, 跳转页码, 每页容量
    def __init__(self, item_count, page_index=1, page_size=10):
        self.item_count = item_count
        self.page_size = page_size
        # 最多能显示的页数
        self.page_count = item_count // page_size + (1 if item_count % page_size > 0 else 0)
        # 超出页码范围
        if (item_count == 0) or (page_index > self.page_count):
            self.offset = 0
            self.limit = 0
            self.page_index = 1
        else:
            self.page_index = page_index
            # 偏移的条目数
            self.offset = self.page_size * (page_index - 1)
            self.limit = self.page_size
        self.has_next = self.page_index < self.page_count
        self.has_previous = self.page_index > 1

    def __str__(self):
        return 'item_count: %s, page_count: %s, page_index: %s, page_size: %s, offset: %s, limit: %s' % (self.item_count, self.page_count, self.page_index, self.page_size, self.offset, self.limit)

    __repr__ = __str__

if __name__ == '__main__':
    # doctest模块搜索类似于交互式Python会话的文本段然后执行来验证是否如所示的那样
    import doctest
    doctest.testmod()

在handlers.py中实现获取博客的API和管理页面:

@get('/api/blogs')
async def api_blogs(*, page='1'):
    page_index = get_page_index(page)
    # select count(id)计算not null值个数
    num = await Blog.findNumber('count(id)')
    p = Page(num, page_index)
    if num == 0:
        return dict(page=p, blogs=())
    # LIMIT 5,10; 返回第6-15行数据
    blogs = await Blog.findAll(orderBy='created_at desc', limit=(p.offset, p.limit))
    return dict(page=p, blogs=blogs)

@get('/manage/blogs')
def manage_blogs(*, page='1'):
    return {
        '__template__': 'manage_blogs.html',
        'page_index': get_page_index(page)
    }

模板页面首先通过API:GET /api/blogs?page=?拿到Model,然后,通过Vue初始化MVVM,View的容器是#vm,包含一个table,我们用v-repeat可以把Model的数组blogs直接变成多行的:

{% extends '__base__.html' %}
{% block title %}日志{% endblock %}
{% block beforehead %}

{% endblock %}
{% block content %}
    
正在加载...
新日志
标题 / 摘要 作者 创建时间 操作
{% endblock %}

先为Web App创建一个新博客:


(十二)日志列表页_第1张图片

然后浏览器输入“IP地址:端口号/manage/blogs”,就可以显示出来了:


(十二)日志列表页_第2张图片

你可能感兴趣的:((十二)日志列表页)