<dl id="vorq8"><menu id="vorq8"></menu></dl>

<sup id="vorq8"></sup>
<sup id="vorq8"></sup>
<sup id="vorq8"></sup>

<optgroup id="vorq8"><address id="vorq8"></address></optgroup>

    <sup id="vorq8"><menu id="vorq8"><small id="vorq8"></small></menu></sup>

    <div id="vorq8"><tr id="vorq8"><object id="vorq8"></object></tr></div>

    当前位置:  首页  >  PHP教程  >  PHP 应用  >  知识库

    在Python的web框架中中编写日志列表的教程

    这篇文章主要介绍了在Python中编写日志列表的教程,示例代码基于Python2.x版本,需要的朋友可以参考下
    MVVM模式不但可用于Form表单,在复杂的管理页面中也能大显身手。例如,分页显示Blog的功能,我们先把后端代码写出来:

    在apis.py中定义一个Page类用于存储分页信息:

    class Page(object):
      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 < 1) 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
    
    

    在urls.py中实现API:

    def _get_blogs_by_page():
      total = Blog.count_all()
      page = Page(total, _get_page_index())
      blogs = Blog.find_by('order by created_at desc limit ?,?', page.offset, page.limit)
      return blogs, page
    
    @api
    @get('/api/blogs')
    def api_get_blogs():
      blogs, page = _get_blogs_by_page()
      return dict(blogs=blogs, page=page)
    
    

    返回模板页面:

    @view('manage_blog_list.html')
    @get('/manage/blogs')
    def manage_blogs():
      return dict(page_index=_get_page_index(), user=ctx.request.user)
    
    

    模板页面首先通过API:GET /api/blogs?page=?拿到Model:

    {
      "page": {
        "has_next": true,
        "page_index": 1,
        "page_count": 2,
        "has_previous": false,
        "item_count": 12
      },
      "blogs": [...]
    }
    
    

    然后,通过Vue初始化MVVM:

    《script》
    function initVM(data) {
      $('#p-blogs').show();
      var vm = new Vue({
        el: '#p-blogs',
        data: {
          blogs: data.blogs,
          page: data.page
        },
        methods: {
          previous: function () {
            gotoPage(this.page.page_index - 1);
          },
          next: function () {
            gotoPage(this.page.page_index + 1);
          },
          edit_blog: function (blog) {
            location.assign('/manage/blogs/edit/' + blog.id);
          }
        }
      });
    }
    
    $(function() {
      getApi('/api/blogs?page={{ page_index }}', function (err, results) {
        if (err) {
          return showError(err);
        }
        $('#p-loading').hide();
        initVM(results);
      });
    });
    《script》
    
    

    View的容器是#p-blogs,包含一个table,我们用v-repeat可以把Model的数组blogs直接变成多行的:

    标题 / 摘要 作者 创建时间 操作

    往Model的blogs数组中增加一个Blog元素,table就神奇地增加了一行;把blogs数组的某个元素删除,table就神奇地减少了一?#23567;?#25152;有复杂的Model-View的?#25104;?#36923;辑全部由MVVM框架完成,我们只需要在HTML中写上v-repeat指令,就什么都不用管了。

    可以把v-repeat="blog: blogs"看成循环代码,所以,可以在一个内部引用循环变量blog。v-text和v-attr指令分别用于生成文本和DOM节点属性。

    完整的Blog列表页如下:

    2015430104720938.png (497×539)

    吐了个 "CAO" !
    • 苹果   2018-10-13 11:56:42
    • lly88   2018-12-26 13:26:28
      不错,O(∩_∩)O谢谢[url=http://www.df5d.com]php二次开发[/url]
    扫码关注 PHP1 官方微信号
    PHP1.CN | 中国最专业的PHP中文社区 | PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | PHP问答
    Copyright ? 1998 - 2020 PHP1.CN. All Rights Reserved PHP1.CN 第一PHP社区 版权所有
         
    pc蛋蛋
    <dl id="vorq8"><menu id="vorq8"></menu></dl>

    <sup id="vorq8"></sup>
    <sup id="vorq8"></sup>
    <sup id="vorq8"></sup>

    <optgroup id="vorq8"><address id="vorq8"></address></optgroup>

      <sup id="vorq8"><menu id="vorq8"><small id="vorq8"></small></menu></sup>

      <div id="vorq8"><tr id="vorq8"><object id="vorq8"></object></tr></div>

      <dl id="vorq8"><menu id="vorq8"></menu></dl>

      <sup id="vorq8"></sup>
      <sup id="vorq8"></sup>
      <sup id="vorq8"></sup>

      <optgroup id="vorq8"><address id="vorq8"></address></optgroup>

        <sup id="vorq8"><menu id="vorq8"><small id="vorq8"></small></menu></sup>

        <div id="vorq8"><tr id="vorq8"><object id="vorq8"></object></tr></div>

        福利彩票走势图下载 全天计划和值 天津快乐10分选号走势图 无游天下真钱棋牌 腾讯分分彩人工 牌九游戏下载 甘肃11选5手机app官网 体彩20选5中奖 排球的英语怎么写 云南11选5遗漏数据统计表 微信彩票竞猜在哪里 河南快三走势图走势图一定牛 最准单双中特 安徽快3开奖结果走势 大乐透怎么预测最准