@time_is_always_against_us

Как подключить datatable во vue.js?

1. Через официальный способ подключить не удалось:
5e96cddce61d4053147596.png
Вставлял данный код в src/main.js. Результат:
5e96cfb406570871028530.png
Ошибка понятна, но как использовать переменную из main.js в someComponent.vue не ясно.

2. Нагуглил такой способ:
import $ from 'jquery';
    import dt from 'datatables.net-bs4';
    $.fn.DataTable = dt;
    
    export default {
       ...
        $('#myTable').DataTable({ });
        ...
    }

Помогло, но возникла другая проблема. Таблица отображается в компоненте Show.vue, который обслуживает роут:
info/history/:type (type: current, closed). При переходе с current на closed менялся только роут в строке браузера, но таблица не перерисовывается без watch за $route:
watch: {
            $route() {
                this.loadInfo();
            }
        },

А в таком случае DataTable начинает ругаться, что не может пересоздать таблицу:
5e96d503906c6430592891.png

Пробовал решить через встроенный в DataTable методы удаления clear / destory:
if(this.dataTable !== undefined) {
                    this.dataTable.destroy(); // Удаляю прежнюю таблицу перед созданием новой
                }

Но DataTable говорит, что не может найти метод destroy:
5e96d5bd397e0328688491.png

Полный код выглядит так:
<script>
    import $ from 'jquery';
    import dt from 'datatables.net-bs4';
    $.fn.DataTable = dt;

    export default {
        store,
        data() {
            return {
                dataTable: undefined,
                table: [],
            }
        },

        watch: {
/* Чтобы подгружать новые данные с сервере при переходе с type = current на type = closed и обратно */
            $route() {
                this.loadInfo();
            }
        },
        methods: {
            async loadInfo() {
 /* Получили данные из DB */
                await axios.get('/api/data/' + this.$route.params.type + '?page=' + this.$route.query.page)
                    .then(({data}) => {
                        this.table = data.infoFromDb;
                    });

/* По документации это должно удалять старую таблицу */
                if(this.dataTable !== undefined) {
                    this.dataTable.destroy();
                }

/* Применяю DataTable*/
                this.dataTable = $('#myTable').DataTable({ });
            }
        },
        mounted() {
            this.loadInfo();
        },
    }
</script>


Итого:
1. Возможно неверно подключаю datatable...
2. Возможно вместо watch -> $route, есть другой способ заставить vue перерисовывать компонент с 0, тогда ошибки "Uncaught (in promise) TypeError: _this.dataTable.destroy" просто не возникнет.
3. Удобных аналогов dataTable не нашел.
Что посоветуете?
  • Вопрос задан
  • 632 просмотра
Пригласить эксперта
Ответы на вопрос 2
VladZen
@VladZen
front-end developer
Почему именно datatables? Есть более удачные решения без необходимости подключать jQuery. vue-tables-2, vuetable-2
Ответ написан
@kvanyi
А так пробовали?
...
var
that = this;
....
$('#myTable').DataTable().destroy();
....
this.$nextTick(function(){
that.table = $('#myTable').DataTable({
});
....
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы