CakePHP 3.6.14:Bootstrap表按html而不是文本排序

问题描述 投票:0回答:1

我正在使用bootstrap tablecakephp。每个单元格的内容都是一个链接,所以为了显示文本而不是html代码我在data-escape="false"标签中使用<table>

但是现在当我尝试排序时,排序没有按预期工作,因为它根据链接的html代码而不是显示的文本对行进行排序。

这是我的表:

<table class="table responsive" id="table" data-toggle="table"
    data-search="true"
    data-filter-control="true" 
    data-show-export="true"
    data-click-to-select="true"
    data-toolbar="#toolbar"
    data-escape="false">
    <thead>
        <tr>
              <th data-field="name" data-filter-control="input" data-sortable="true" scope="col"><?= __('Title') ?></th>
        </tr>
    </thead>
    <tbody>
       <?php foreach ($tasks as $task):?>
           <tr>
              <td><?= $task->has('name') ? $this->Html->link($task->name, ['controller' => 'Tasks', 'action' => 'edit', $task->id]) : '' ?></td>
           </tr>
       <?php endforeach; ?>
   </tbody>
</table>
php html cakephp bootstrap-table
1个回答
3
投票

您可以使用自己的javascript分拣机和“数据分拣机”属性。

<th data-field="name" data-filter-control="input" data-sortable="true" data-sorter="linksSorter" scope="col"><?= __('Title') ?></th>

然后例如:

function linksSorter(a, b) {
    var a = $(a).text();
    var b = $(b).text();
    if (a < b) return -1;
    if (a > b) return 1;

    return 0;
}
© www.soinside.com 2019 - 2024. All rights reserved.