0

Datatable cơ bản

Chào bạn đọc!

Hôm nay mình xin chia sẻ về Datatable - một plug-in cho Jquery giúp tạo và tương tác với bảng dữ liệu dễ dàng hơn.

Datatable đem lại những gì

  • Hỗ trợ tạo bảng có phân trang, tìm kiếm tức thời, sắp xếp nhiều cột
  • Hỗ trợ nhiều nguồn dữ liệu: DOM, Javascript, Ajax
  • Dễ dàng thay đổi giao diện: DataTables, jQuery UI, Bootstrap, Foundation,...
  • Có nhiều phần mở rộng hỗ trợ khác: Editor, Buttons, FixedColumns,...

Giao diện

Capture.PNG

Cài đặt

npm install datatables.net
npm install datatables.net-dt
bower install --save datatables.net=
bower install --save datatables.net-dt
  • Sử dụng code online
<link rel="stylesheet" href="https://cdn.datatables.net/1.10.12/css/jquery.dataTables.min.css"/>
<script type="text/javascript" src="https://cdn.datatables.net/1.10.12/js/jquery.dataTables.min.js"></script>

Chú ý: Phải cho thẻ script của DataTable xuống dưới thẻ script của Jquery để có thể sử dụng được.

Sử dụng

Html data

Sử dụng dữ liệu ngay trong thẻ HTML

<table id="example" class="display" width="100%" cellspacing="0">
        <thead>
            <tr>
                <th>Name</th>
                <th>Office</th>
                <th>Age</th>
            </tr>
        </thead>
        <tfoot>
            <tr>
                <th>Name</th>
                <th>Office</th>
                <th>Age</th>
            </tr>
        </tfoot>
        <tbody>
            <tr>
                <td>Tiger Nixon</td>
                <td>Edinburgh</td>
                <td>61</td>
            </tr>
            <tr>
                <td>Garrett Winters</td>
                <td>Tokyo</td>
                <td>63</td>
            </tr>
            <tr>
                <td>Ashton Cox</td>
                <td>San Francisco</td>
                <td>66</td>
            </tr>
            <tr>
                <td>Cedric Kelly</td>
                <td>Edinburgh</td>
                <td>22</td>
            </tr>
            <tr>
                <td>Airi Satou</td>
                <td>Tokyo</td>
                <td>33</td>
            </tr>
            <tr>
                <td>Brielle Williamson</td>
                <td>New York</td>
                <td>61</td>
            </tr>
            <tr>
                <td>Herrod Chandler</td>
                <td>San Francisco</td>
                <td>59</td>
            </tr>
            <tr>
                <td>Rhona Davidson</td>
                <td>Tokyo</td>
                <td>55</td>
            </tr>
            <tr>
                <td>Colleen Hurst</td>
                <td>San Francisco</td>
                <td>39</td>
            </tr>
            <tr>
                <td>Sonya Frost</td>
                <td>Edinburgh</td>
                <td>23</td>
            </tr>
            <tr>
                <td>Jena Gaines</td>
                <td>London</td>
                <td>30</td>
            </tr>
            <tr>
                <td>Quinn Flynn</td>
                <td>Edinburgh</td>
                <td>22</td>
            </tr>
            <tr>
                <td>Charde Marshall</td>
                <td>San Francisco</td>
                <td>36</td>
            </tr>
        </tbody>
    </table>
$(document).ready(function() {
    $('#example').DataTable();
});

Array data

Sử dụng dữ liệu là một mảng javascript

var data = [
    [
        "Tiger Nixon",
        "System Architect",
        "Edinburgh",
        "5421",
        "2011/04/25",
        "$3,120"
    ],
    [
        "Garrett Winters",
        "Director",
        "Edinburgh",
        "8422",
        "2011/07/25",
        "$5,300"
    ]
];
$('#example').DataTable( {
    data: data,
    columns: [
        {title: "Name"},
        {title: "Position"},
        {title: "Office"},
        {title: "Extn."},
        {title: "Start date"},
        {title: "Salary"}
    ]
});
<table id="example" class="display" width="100%"></table>

Object data

var data = [
    {
        "name":       "Tiger Nixon",
        "position":   "System Architect",
        "salary":     "$3,120",
        "start_date": "2011/04/25",
        "office":     "Edinburgh",
        "extn":       "5421"
    },
    {
        "name":       "Garrett Winters",
        "position":   "Director",
        "salary":     "$5,300",
        "start_date": "2011/07/25",
        "office":     "Edinburgh",
        "extn":       "8422"
    }
];
$('#example').DataTable( {
    data: data,
    columns: [
        { data: 'name' },
        { data: 'position' },
        { data: 'salary' },
        { data: 'office' }
    ]
});
<table id="example" class="display" width="100%" cellspacing="0">
    <thead>
        <tr>
            <th>Name</th>
            <th>Position</th>
            <th>Salary</th>
            <th>Office</th>
        </tr>
    </thead>
    <tfoot>
        <tr>
            <th>Name</th>
            <th>Position</th>
            <th>Salary</th>
            <th>Office</th>
        </tr>
    </tfoot>
</table>

Sử dụng Ajax

{
    "name": "Tiger Nixon",
    "hr": {
        "position": "System Architect",
        "salary": "$320,800",
        "start_date": "2011/04/25"
    },
    "contact": {
        "office": "Edinburgh",
        "extn": "5421"
    }
}
$('#myTable').DataTable({
    ajax: 'http://link-ajax',
    columns: [
        { data: 'name' },
        { data: 'hr.position' },
        { data: 'hr.salary' },
        { data: 'contact.office' },
    ]
});
<table id="example" class="display" width="100%" cellspacing="0">
    <thead>
        <tr>
            <th>Name</th>
            <th>Position</th>
            <th>Salary</th>
            <th>Office</th>
        </tr>
    </thead>
    <tfoot>
        <tr>
            <th>Name</th>
            <th>Position</th>
            <th>Salary</th>
            <th>Office</th>
        </tr>
    </tfoot>
</table>

Một số tùy chọn cơ bản

DataTable có một số tùy chọn cơ bản sau đây

$('#myTable').DataTable({
    'columns': [
        {
            'searchable': false, //giá trị false nếu không muốn tìm kiếm cột này
            'orderable': false, //Chỉ định cột không sắp xếp
            'defaultContent': '' //Giá trị mặc định của ô tướng ứng với cột này
        },
        {
            'orderable': false,
            'searchable': false,
            'className': 'example_edit center', //class của từng ô trong cột, tính cả ô trong thead và tfoot
            'defaultContent': '<i class="fa fa-edit"></i>'
        },
    ]

Một số sự kiện cơ bản

draw: Sự kiện sảy ra khi bảng Datatable hoàn thành việc vẽ các hàng và cột

order: Sự kiện sảy ra khi một cột trong bảng được sắp xếp

processing: Sự kiện sảy ra khi bảng Datatable đang xử lý dữ liệu

search: Sự kiện sảy ra khi người dùng tìm kiếm

Ví dụ:

$('#example').on('draw.dt', function () {
    alert( 'Table draw' );
});

Kết luận

Hi vọng sau bài viết này các bạn có cái nhìn sơ qua về cách tạo bảng dữ liệu bằng DataTable và có thể tự tạo một bảng dữ liệu theo phong cách DataTable.

Chúc các bạn thành công!


All Rights Reserved

Viblo
Let's register a Viblo Account to get more interesting posts.