效果图

代码说明

操作指南
- 修改虚拟环境中的 模板 base.html
| cd venv/lib/python2.7/site-packages/flask_admin/templates/bootstrap3/admin | 
内容如下:{% import 'admin/layout.html' as layout with context -%}
{% import 'admin/static.html' as admin_static with context %}
<html>
   <head>
    <title>{% block title %}{% if admin_view.category %}{{ admin_view.category }} - {% endif %}{{ admin_view.name }} - {{ admin_view.admin.name }}{% endblock %}</title>
    {% block head_meta %}
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta name="description" content="">
        <meta name="author" content="">
    {% endblock %}
    {% block head_css %}
        <link href="{{ admin_static.url(filename='bootstrap/bootstrap3/swatch/{swatch}/bootstrap.min.css'.format(swatch=config.get('FLASK_ADMIN_SWATCH', 'default')), v='3.3.5') }}" rel="stylesheet">
        {%if config.get('FLASK_ADMIN_SWATCH', 'default') == 'default' %}
        <link href="{{ admin_static.url(filename='bootstrap/bootstrap3/css/bootstrap-theme.min.css', v='3.3.5') }}" rel="stylesheet">
        {%endif%}
        <link href="{{ admin_static.url(filename='admin/css/bootstrap3/admin.css', v='1.1.1') }}" rel="stylesheet">
	<link href="{{ admin_static.url(filename='admin/css/bootstrap3/submenu.css') }}" rel="stylesheet">
        {% if admin_view.extra_css %}
          {% for css_url in admin_view.extra_css %}
            <link href="{{ css_url }}" rel="stylesheet">
          {% endfor %}
        {% endif %}
        <style>
        body {
            padding-top: 4px;
        }
        </style>
           <link rel="stylesheet" href="https://unpkg.com/@fortawesome/fontawesome-free@5.12.1/css/all.min.css">
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.1/jquery.min.js"
            integrity="sha512-bLT0Qm9VnAYZDflyKcBaQ2gg0hSYNQrJ8RilYldYQ1FxQYoCLtUjuuRuZo+fjqhx/qtq/1itJ0C2ejDxltZVFg=="
            crossorigin="anonymous"></script>
       <link href="https://unpkg.com/bootstrap-table@1.18.0/dist/bootstrap-table.min.css" rel="stylesheet">
    <script src="https://unpkg.com/bootstrap-table@1.18.0/dist/bootstrap-table.min.js"></script>
    <script id="_carbonads_projs" type="text/javascript"
            src="https://srv.carbonads.net/ads/CK7DL2J7.json?segment=placement:bootstrap-tablecom&callback=_carbonads_go"></script>
    {% endblock %}
    {% block head %}
    {% endblock %}
    {% block head_tail %}
    {% endblock %}
  </head>
  <body>
    {% block page_body %}
    <div class="container{%if config.get('FLASK_ADMIN_FLUID_LAYOUT', False) %}-fluid{% endif %}">
      <nav class="navbar navbar-default" role="navigation">
        <!-- Brand and toggle get grouped for better mobile display -->
        <div class="navbar-header">
          <button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#admin-navbar-collapse">
            <span class="sr-only">Toggle navigation</span>
            <span class="icon-bar"></span>
            <span class="icon-bar"></span>
            <span class="icon-bar"></span>
          </button>
          {% block brand %}
          <a class="navbar-brand" href="{{ admin_view.admin.url }}">{{ admin_view.admin.name }}</a>
          {% endblock %}
        </div>
        <!-- navbar content -->
        <div class="collapse navbar-collapse" id="admin-navbar-collapse">
          {% block main_menu %}
          <ul class="nav navbar-nav">
            {{ layout.menu() }}
          </ul>
          {% endblock %}
          {% block menu_links %}
          <ul class="nav navbar-nav navbar-right">
            {{ layout.menu_links() }}
          </ul>
          {% endblock %}
          {% block access_control %}
          {% endblock %}
        </div>
      </nav>
      {% block messages %}
      {{ layout.messages() }}
      {% endblock %}
      {# store the jinja2 context for form_rules rendering logic #}
      {% set render_ctx = h.resolve_ctx() %}
      {% block body %}{% endblock %}
    </div>
    {% endblock %}
{% block tail_js %}
    <script src="{{ admin_static.url(filename='vendor/jquery.min.js', v='2.1.4') }}" type="text/javascript"></script>
    <script src="{{ admin_static.url(filename='bootstrap/bootstrap3/js/bootstrap.min.js', v='3.3.5') }}" type="text/javascript"></script>
    <script src="{{ admin_static.url(filename='vendor/moment.min.js', v='2.9.0') }}" type="text/javascript"></script>
    <script src="{{ admin_static.url(filename='vendor/select2/select2.min.js', v='3.5.2') }}" type="text/javascript"></script>
    {% if admin_view.extra_js %}
      {% for js_url in admin_view.extra_js %}
        <script src="{{ js_url }}" type="text/javascript"></script>
      {% endfor %}
    {% endif %}
    {% endblock %}
    {% block tail %}
    {% endblock %}
  </body>
</html>
- 修改 list.html
| vim venv/lib/python2.7/site-packages/flask_admin/templates/bootstrap3/admin/model/list.html | 
list.html明细如下{% extends 'admin/master.html' %}
{% import 'admin/lib.html' as lib with context %}
{% import 'admin/static.html' as admin_static with context%}
{% import 'admin/model/layout.html' as model_layout with context %}
{% import 'admin/actions.html' as actionlib with context %}
{% import 'admin/model/row_actions.html' as row_actions with context %}
{% block head %}
{{ super() }}
{{ lib.form_css() }}
{% endblock %}
{% block body %}
<div class="panel panel-default">
    <div class="panel-body">
        {% block title %}{% if admin_view.category %}{{ admin_view.category }} - {% endif %}{{ admin_view.name }}{%
        endblock %}
    </div>
</div>
{% block model_menu_bar %}
<ul class="nav nav-tabs actions-nav">
    <li class="active">
        <a href="javascript:void(0)">{{ _gettext('List') }}{% if count %} ({{ count }}){% endif %}</a>
    </li>
    {% if admin_view.can_create %}
    <li>
        {%- if admin_view.create_modal -%}
        {{ lib.add_modal_button(url=get_url('.create_view', url=return_url, modal=True), title=_gettext('Create New
        Record'), content=_gettext('Create')) }}
        {% else %}
        <a href="{{ get_url('.create_view', url=return_url) }}" title="{{ _gettext('Create New Record') }}">{{
            _gettext('Create') }}</a>
        {%- endif -%}
    </li>
    {% endif %}
    {% if admin_view.can_export %}
    {{ model_layout.export_options() }}
    {% endif %}
    {% block model_menu_bar_before_filters %}{% endblock %}
    {% if filters %}
    <li class="dropdown">
        {{ model_layout.filter_options() }}
    </li>
    {% endif %}
    {% if can_set_page_size %}
    <li class="dropdown">
        {{ model_layout.page_size_form(page_size_url) }}
    </li>
    {% endif %}
    {% if actions %}
    <li class="dropdown">
        {{ actionlib.dropdown(actions) }}
    </li>
    {% endif %}
    {% if search_supported %}
    <li>
        {{ model_layout.search_form() }}
    </li>
    {% endif %}
    {% block model_menu_bar_after_filters %}{% endblock %}
</ul>
{% endblock %}
{% if filters %}
{{ model_layout.filter_form() }}
<div class="clearfix"></div>
{% endif %}
{% block model_list_table %}
<div class="table table-striped table-bordered table-hover model-list" style="white-space:nowrap">
    <table
            id="booboo_table"
            data-toggle="table"
            data-show-columns="true"
            data-show-footer="true">
        <thead>
        <tr>
            {% block list_header scoped %}
            {% if actions %}
            <th class="list-checkbox-column">
                <input type="checkbox" name="rowtoggle" class="action-rowtoggle"
                       title="{{ _gettext('Select all records') }}"/>
            </th>
            {% endif %}
            {% block list_row_actions_header %}
            {% if admin_view.column_display_actions %}
            <th class="col-md-1" data-field="id" data-footer-formatter="idFormatter"></th>
            {% endif %}
            {% endblock %}
            {% for c, name in list_columns %}
            {% set column = loop.index0 %}
            {% if name in ["充值金额","充值不含税","充值税额","应收金额","应收不含税","应收税额","发票金额","不含税金额","税额","本月确认成本","本月确认收入",
            "累计应收金额"
            ,"累计应收不含税"
            ,"累计应收税额"
            ,"累计充值金额"
            ,"累计充值不含税"
            ,"累计充值税额"
            ,"累计发票金额"
            ,"累计发票不含税金额"
            ,"累计发票税额"
            ,"累计确认收入"
            ,"累计未确认收入不含税"
            ,"累计未索取发票金额"] %}
            <th data-field="price" data-footer-formatter="priceFormatter" class="column-header col-{{c}}">
                {% else %}
            <th class="column-header col-{{c}}">
                {% endif %}
                {% if admin_view.is_sortable(c) %}
                {% if sort_column == column %}
                <a href="{{ sort_url(column, True) }}" title="{{ _gettext('Sort by %(name)s', name=name) }}">
                    {{ name }}
                    {% if sort_desc %}
                    <span class="fa fa-chevron-up glyphicon glyphicon-chevron-up"></span>
                    {% else %}
                    <span class="fa fa-chevron-down glyphicon glyphicon-chevron-down"></span>
                    {% endif %}
                </a>
                {% else %}
                <a href="{{ sort_url(column) }}" title="{{ _gettext('Sort by %(name)s', name=name) }}">{{ name }}</a>
                {% endif %}
                {% else %}
                {{ name }}
                {% endif %}
                {% if admin_view.column_descriptions.get(c) %}
                <a class="fa fa-question-circle glyphicon glyphicon-question-sign"
                   title="{{ admin_view.column_descriptions[c] }}"
                   href="javascript:void(0)" data-role="tooltip"
                ></a>
                {% endif %}
            </th>
            {% endfor %}
            {% endblock %}
        </tr>
        </thead>
        {% for row in data %}
        <tr>
            {% block list_row scoped %}
            {% if actions %}
            <td>
                <input type="checkbox" name="rowid" class="action-checkbox" value="{{ get_pk_value(row) }}"
                       title="{{ _gettext('Select record') }}"/>
            </td>
            {% endif %}
            {% block list_row_actions_column scoped %}
            {% if admin_view.column_display_actions %}
            <td class="list-buttons-column">
                {% block list_row_actions scoped %}
                {% for action in list_row_actions %}
                {{ action.render_ctx(get_pk_value(row), row) }}
                {% endfor %}
                {% endblock %}
            </td>
            {%- endif -%}
            {% endblock %}
            {% for c, name in list_columns %}
            <td class="col-{{c}}">
                {% if admin_view.is_editable(c) %}
                {% set form = list_forms[get_pk_value(row)] %}
                {% if form.csrf_token %}
                {{ form[c](pk=get_pk_value(row), display_value=get_value(row, c), csrf=form.csrf_token._value()) }}
                {% else %}
                {{ form[c](pk=get_pk_value(row), display_value=get_value(row, c)) }}
                {% endif %}
                {% else %}
                {{ get_value(row, c) }}
                {% endif %}
            </td>
            {% endfor %}
            {% endblock %}
        </tr>
        {% else %}
        <tr>
            <td colspan="999">
                {% block empty_list_message %}
                <div class="text-center">
                    {{ admin_view.get_empty_list_message() }}
                </div>
                {% endblock %}
            </td>
        </tr>
        {% endfor %}
    </table>
</div>
<!--booboo test-->
<script>
  function idFormatter() {
    return 'Total'
  }
  function nameFormatter(data) {
    return data.length
  }
  function priceFormatter(data) {
    var field = this.field
    return '$' + data.map(function (row) {
      return +row[field].substring(1)
    }).reduce(function (sum, i) {
      return sum + i
    }, 0)
  }
</script>
<!--booboo test-->
{% block list_pager %}
{% if num_pages is not none %}
{{ lib.pager(page, num_pages, pager_url) }}
{% else %}
{{ lib.simple_pager(page, data|length == page_size, pager_url) }}
{% endif %}
{% endblock %}
{% endblock %}
{% block actions %}
{{ actionlib.form(actions, get_url('.action_view')) }}
{% endblock %}
{%- if admin_view.edit_modal or admin_view.create_modal or admin_view.details_modal -%}
{{ lib.add_modal_window() }}
{%- endif -%}
{% endblock %}
{% block tail %}
{{ super() }}
{% if filter_groups %}
<div id="filter-groups-data" style="display:none;">{{ filter_groups|tojson|safe }}</div>
<div id="active-filters-data" style="display:none;">{{ active_filters|tojson|safe }}</div>
{% endif %}
<script src="{{ admin_static.url(filename='admin/js/filters.js', v='1.0.0') }}"></script>
{{ lib.form_js() }}
{{ actionlib.script(_gettext('Please select at least one record.'),
actions,
actions_confirmation) }}
{% endblock %}
操作记录
| /alidata/fms-backup/venv/lib/python2.7/site-packages/flask_admin/templates/bootstrap3/admin | 
demo
| 
 |