Где разместить JQuery в компоненте React?

Я использую библиотеку materialize css в своем приложении React. Итак, я хочу использовать «модальный» из него. Есть 2 способа его инициализации:

document.addEventListener('DOMContentLoaded', function() {
var elems = document.querySelectorAll('.modal');
var instances = M.Modal.init(elems, options);
 });

// Or with jQuery

$(document).ready(function(){
$('.modal').modal();
});

Итак, я обычно делаю 2-й способ:

componentDidMount() {
    const $ = window.$;
    $('.dropdown-trigger').dropdown();
    $(document).ready(function () {
        $('.modal').modal();
    })
}

И все это работало для меня, но теперь у меня есть дополнительный метод в моем ComponentDidMount(), который запрашивает API сервера:

componentDidMount() {
    this.getCurrentUser();
    const $ = window.$;
    $('.dropdown-trigger').dropdown();
    $(document).ready(function () {
        $('.modal').modal();
    })
}

getCurrentUser() {
    fetch('api/user/'+ localStorage.getItem("currentUser") +'/me', {
        method: 'GET',
        headers: {
            'Accept': 'application/json',
            'Content-Type': 'application/json'
        }
    })
        .then(response => {
            if (!response.ok) {
                this.setState({
                    isLoadong: false,
                    failed: true
                })
            }
            else {
                response.json().then(user => {
                    this.setState({
                        user: user,
                        isLoadong: false,
                        failed: false
                    })
                });
            }
        })
}

Так почему модальное окно не работает сейчас? Как сделать все правильно?

Не надо! Используйте библиотеку реактивных материалов

charlietfl 04.04.2019 22:46

Это довольно плохая реализация. Я бы посоветовал изучить библиотеки реагирования, которые вы могли бы использовать. В сети их куча!

Rachel Nicolas 04.04.2019 23:03
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
1
2
52
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вы хотите использовать jQuery только в конечных узлах древовидной структуры вашего приложения React. Если у этого компонента есть дочерние компоненты, это плохая идея. Если это компонент листового узла, вам нужно поместить свою логику jQuery в функцию componentDidMount().

На этой странице есть полезные материалы по теме: https://reactjs.org/docs/интеграция-с-другими-библиотеками.html

Спасибо! И у вас есть идея, почему он перестает работать, когда я добавляю метод this.getCurrentUser() в componentDidMount?

Nick Kulese 04.04.2019 23:02

Извините, я не знаю. Это не выглядит плохо. Я бы попробовал добавить улов после вашего тогда. Что-то вроде .then(// code).catch((err) => { console.info('error: ' + err); })

jtylerm 05.04.2019 16:45

Другие вопросы по теме