質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.48%

Datatablesでデータを追加した後、表示項目外でソート順を決定したい

受付中

回答 0

投稿

  • 評価
  • クリップ 0
  • VIEW 105

score 0

前提・実現したいこと

jQueryのプラグインであるDataTablesで表を作成しています。
表の特定の列が特定の値の時、表示内容を変更しつつもソートは元の値で行いたいと考えております。
下記例では以下を表現しております。

  • 当該列のデータが2の時、表示は「弐」でソートは「2」で行いたい

発生している問題・エラーメッセージ

元の値でソートすることができません。
下記例であれば、「1」「弐」「3」「4」でソートが行われてしまいます。

該当のソースコード

<!DOCTYPE html>
<html lang="ja">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>sample</title>
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.0/css/bootstrap.min.css" integrity="sha384-9aIt2nRpC12Uk9gS9baDl411NQApFmC26EwAOH8WgZl5MYYxFfc+NcPb1dKGj7Sk" crossorigin="anonymous">
    <link rel="stylesheet" href="https://cdn.datatables.net/1.10.25/css/jquery.dataTables.min.css">
</head>
<body>
    <button id="add_data">add data</button>
    <table id="table_id" class="display">
        <thead>
            <tr>
                <th>Column 1</th>
            </tr>
        </thead>
        <tbody>
        </tbody>
    </table>

    <script src="https://code.jquery.com/jquery-3.5.1.slim.min.js" integrity="sha384-DfXdz2htPH0lsSSs5nCTpuj/zy4C+OGpamoFVy38MVBnE+IbbVYUew+OrCXaRkfj" crossorigin="anonymous"></script>
    <script src="https://cdn.jsdelivr.net/npm/popper.js@1.16.0/dist/umd/popper.min.js" integrity="sha384-Q6E9RHvbIyZFJoft+2mJbHaEWldlvI9IOYy5n3zV9zzTtmI3UksdQRVvoxMfooAo" crossorigin="anonymous"></script>
    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.5.0/js/bootstrap.min.js" integrity="sha384-OgVRvuATP1z7JjHLkuOU7Xw704+h835Lr+6QL9UvYjZE3Ipu6Tp75j7Bh/kR0JKI" crossorigin="anonymous"></script>
    <script src="https://cdn.datatables.net/1.10.25/js/jquery.dataTables.min.js"></script>
    <!-- 下記Javascript -->
    <script src="./table.js"></script>
</body>
</html>
/* table.js */
$(document).ready( function () {
    variants_table = $('#table_id').DataTable({
        columns: [
            {
                "data": "some_no",
                "render":function ( data, type, full, meta ) {
                    // dataが特定の値のときに表示形式を変更する処理
                    if(data == 2){
                        return "弐"
                    }
                    return data;
                },
                "createdCell": function (td, cellData, rowData, row, col) {
                    // 並び順を設定
                    $(td).attr("data-order", rowData["some_no"]);
                    $(td).attr("data-sort", rowData["some_no"]);
                }
            }
        ]
    });
    variants_table.draw()

    // Ajaxで取得したデータを想定
    addData = [
        {"some_no":1},
        {"some_no":2},
        {"some_no":3},
        {"some_no":4},
    ]

    // 画面上部のボタン押下でデータを追加し再描画(Ajaxで取得したデータの挿入と再描画を想定)
    $("#add_data").click(function(){
        var dt = $('#table_id').DataTable()
        dt.clear()
        $('#table_id').dataTable().fnAddData(addData)
        dt.order([[ 0, "asc" ]])
        dt.draw()
    })
} );

試したこと

createdCellでtdに以下を付与しましたが、並び順は変更できませんでした。

  • data-order
  • data-sort

また、元の値でソートしたのちセルが生成されることを期待し、renderのみにしてみましたが、renderで変更された内容でソートされるような挙動をしております。

補足情報(FW/ツールのバージョンなど)

  • jQuert 3.1.5
  • Datatables 1.10.25
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

まだ回答がついていません

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.48%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る