bootstrap-table 汇总行/页脚不显示footerFormatter不执行问题

在使用Bootstrap-table时遇到一个奇怪的问题,一个表格的页脚不显示,footerFormatter函数未执行。经过源码排查,发现在列不可见的情况下,方法会直接返回,导致页脚不生成。解决办法是避免使用隐藏列,以确保footer能正常工作。

 同一个页面两个bootstrap-table表格,使用完全一样的options,其中一个却不显示页脚,footerFormatter 函数里面 debugger;发现根本不进去函数。

各种百度goole都找不到原因,无奈只能去看源码。终于在大概第2604行发现一段奇怪的代码:

{
        key: 'resetFooter',
        value: function resetFooter() {
          var data = this.getData();
          var html = [];

          if (!this.options.showFooter || this.options.cardView) {
            // do nothing
            return;
          }

          if (!this.options.cardView && this.options.detailView) {
            html.push('<td><div class="th-inner">&nbsp;</div><div class="fht-cell"></div></td>');
          }

          var _iteratorNormalCompletion16 = true;
          var _didIteratorError16 = false;
          var _iteratorError16 = undefined;

          try {
            for (var _iterator16 = this.columns[Symbol.iterator](), _step16; !(_iteratorNormalCompletion16 = (_step16 = _iterator16.next()).done); _iteratorNormalCompletion16 = true) {
              var column = _step16.value;

              var falign = '';

              var valign = '';
              var csses = [];
              var style = {};
              var class_ = Utils.sprintf(' class="%s"', column['class']);

              if (!column.visible) {
                return;
              }

              if (this.options.cardView && !column.cardVisible) {
                return;
              }

              falign = Utils.sprintf('text-align: %s; ', column.falign ? column.falign : column.align);
              valign = Utils.sprintf('vertical-align: %s; ', column.valign);
              style = Utils.calculateObjectValue(null, this.options.footerStyle);

              if (style && style.css) {
                var _iteratorNormalCompletion17 = true;
                var _didIteratorError17 = false;
                var _iteratorError17 = undefined;

                try {
                  for (var _iterator17 = Object.keys(style.css)[Symbol.iterator](), _step17; !(_iteratorNormalCompletion17 = (_step17 = _iterator17.next()).done); _iteratorNormalCompletion17 = true) {
                    var _ref21 = _step17.value;

                    var _ref22 = _slicedToArray(_ref21, 2);

                    var key = _ref22[0];
                    var value = _ref22[1];

                    csses.push(key + ': ' + value);
                  }
                } catch (err) {
                  _didIteratorError17 = true;
                  _iteratorError17 = err;
                } finally {
                  try {
                    if (!_iteratorNormalCompletion17 && _iterator17.return) {
                      _iterator17.return();
                    }
                  } finally {
                    if (_didIteratorError17) {
                      throw _iteratorError17;
                    }
                  }
                }
              }

              html.push('<td', class_, Utils.sprintf(' style="%s"', falign + valign + csses.concat().join('; ')), '>');
              html.push('<div class="th-inner">');

              html.push(Utils.calculateObjectValue(column, column.footerFormatter, [data], '&nbsp;') || '&nbsp;');

              html.push('</div>');
              html.push('<div class="fht-cell"></div>');
              html.push('</div>');
              html.push('</td>');
            }
          } catch (err) {
            _didIteratorError16 = true;
            _iteratorError16 = err;
          } finally {
            try {
              if (!_iteratorNormalCompletion16 && _iterator16.return) {
                _iterator16.return();
              }
            } finally {
              if (_didIteratorError16) {
                throw _iteratorError16;
              }
            }
          }

          this.$tableFooter.find('tr').html(html.join(''));
          this.$tableFooter.show();
          clearTimeout(this.timeoutFooter_);
          this.timeoutFooter_ = setTimeout($.proxy(this.fitFooter, this), this.$el.is(':hidden') ? 100 : 0);
        }
      }

 

 看下面截图这段代码,发现问题了吧,如果列不可见,则退出方法 Σ( ° △ °|||)︴ footer是个独立的table,由这个方法动态生成的,所以一但提前return了就不会生成页脚!!!

 

所以要使用页脚只能放弃隐藏列O__O "…

### 鼠标连点器的下载与使用教程 #### 软件功能概述 鼠标连点器是一种能够帮助用户自动完成重复性鼠标点击操作的工具,适用于多种场景,例如游戏操作、办公自动化等。其主要作用在于提升效率并减少手动操作带来的疲劳感[^1]。 #### 下载途径 通常情况下,鼠标连点器可以通过以下几种方式获取: - **官方网站**:许多开发者会提供官方版本供用户免费或付费下载。 - **第三方平台**:部分应用分发网站也会提供此类软件,但在选择时需注意安全性,避免下载到带有恶意代的版本。 - **自制脚本**:对于熟悉编程技术的用户来说,可以利用 Python 等语言自行开发适合自己的鼠标连点器[^4]。 #### 安装过程 安装鼠标连点器的过程相对简单,一般遵循以下流程: 1. 下载完成后打开 `.exe` 文件启动安装向导; 2. 按照提示逐步设置安装路径及其他参数,默认选项即可满足大部分需求; 3. 点击“完成”按钮结束整个安装环节[^2]。 #### 基础配置与使用说明 首次运行该类应用程序后,可能需要进行一定的初始化设定才能正常使用全部特性: - 设置触发条件:定义何时启用连续点击模式,比如通过指定快捷键实现开关控制。 - 自定义频率调节:依据实际应用场景调整每秒钟内的点击次数或者两次之间的时间间隔。 - 功能扩展支持:某些高级产品还允许绑定额外的功能模块,像图片识别定位目标位置再实施动作等功能[^3]。 #### 制作个性化解决方案 (可选) 如果现有市场上的成品无法完全契合个人特殊要求,则考虑借助开源社区资源学习如何构建专属方案也是一个不错的选择。以下是基于 Python 的简易示例代片段用于创建基础型鼠标连点器: ```python import time import threading from pynput.mouse import Button, Controller as MouseController from pynput.keyboard import Listener, KeyCode, Key delay = 0.01 button = Button.left start_stop_key = KeyCode(char='s') exit_key = KeyCode(char='e') class ClickMouse(threading.Thread): def __init__(self, delay, button): super().__init__() self.delay = delay self.button = button self.running = False self.program_running = True def start_clicking(self): self.running = True def stop_clicking(self): self.running = False def exit(self): self.stop_clicking() self.program_running = False def run(self): while self.program_running: while self.running: mouse.click(self.button) time.sleep(self.delay) mouse = MouseController() click_thread = ClickMouse(delay, button) click_thread.start() def on_press(key): if key == start_stop_key: if click_thread.running: click_thread.stop_clicking() else: click_thread.start_clicking() elif key == exit_key: click_thread.exit() listener.stop() with Listener(on_press=on_press) as listener: listener.join() ``` 上述脚本实现了简单的按键切换逻辑来开启/关闭自动点击行为,并提供了退出机制以便安全终止进程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值