<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就神奇地減少了一行。所有復雜的Model-View的映射邏輯全部由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
    掃碼關注 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>