Форум программистов, компьютерный форум, киберфорум
React/ReactJS
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
2 / 2 / 0
Регистрация: 12.02.2010
Сообщений: 116

Получить ссылку на DOM элемент из списка SELECT material-ui

10.02.2021, 21:40. Показов 1397. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Приветствую. Такой вопрос. Есть элемент SELECT из материала, хочу при отрытом выпадающем списке получить доступ к дом элементу этого списка. Я получил доступ, но на мой взгляд решение какое-то не совсем правильное. А именно использование setTimeout. Если его не использовать, то получается что useEffect срабатывает при изменении isOpen раньше чем открывается выпадающий список. И поэтому дом равен null. Немного не укладывается в голове. Ведь useEffect обычно срабатывает после всех изменений в dom.

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
import React from 'react';
import {TextField,Select} from "@material-ui/core";
import './App.css';
 
function App() {
    const [isOpen, setOpen] = React.useState('');
 
 
    let text = React.createRef();
 
 
    React.useEffect(() => {if(isOpen){setTimeout(()=> console.log(text.current),0)}})
 
    return (
        <>
             <Select onOpen={()=>setOpen(!isOpen)}>
                <option ref={text}>kkk</option>
                <option>dddd</option>
            </Select>
        </>
    )
 
}
 
export default App;
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.02.2021, 21:40
Ответы с готовыми решениями:

Как получить ссылку на видео вк c DOM библиотки?
все перепробывал не получаеться((( include &quot;dom.php&quot;; $html = new simple_html_dom(); ...

Передать в аргумент функции ссылку на элемент dom
// Принимаем (ins) ссылку на объект и (a) значение(не суть важно) function upd(ins,a) { if (ins.checked) add(ins.id,a); ...

Получение ссылки на DOM для компонентов material-ui
Всем привет. Подскажите такой момент. Есть компонент SELECT из материал, я сделал выбор в списке и хочу потом получать выбранное значение...

4
Особый статус
 Аватар для FloppyDisc
623 / 221 / 164
Регистрация: 18.11.2015
Сообщений: 1,086
14.02.2021, 00:23
Может стоит прокинуть ревку не в оптион, а в сам селект? И зачем вам useEffect?
0
2 / 2 / 0
Регистрация: 12.02.2010
Сообщений: 116
14.02.2021, 10:08  [ТС]
useEffect для того что бы получить доступ к дому списка, конкретней определённые пункты нужно подсветить. Прокидывал, то же самое. Список открывается после юсэффекта
0
27 / 22 / 6
Регистрация: 13.12.2012
Сообщений: 159
15.02.2021, 11:32
Цитата Сообщение от Slayer110 Посмотреть сообщение
Ведь useEffect обычно срабатывает после всех изменений в dom
В том и дело, что это не так. Сильно упрощая useEffect живет внутри среды React и ничего не знает про dom. В отличии от useLayoutEffect
0
2 / 2 / 0
Регистрация: 12.02.2010
Сообщений: 116
15.02.2021, 21:13  [ТС]
Может вы и правы, отпишусь как попробую.

Добавлено через 17 минут
Ещё не пробовал, но уже прочитал отличие от useEffect. layout вызывается сразу после изменения в виртуал дом, и срабатывает синхронно, а effect запускается именно после внесения изменений в реальный дом, после прорисовки в браузере.

Добавлено через 36 секунд
То есть layout идёт перед effect
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.02.2021, 21:13
Помогаю со студенческими работами здесь

Возможно ли создать вложенный DOM объект в Jquery и этим же действием получить ссылку на самый глубокий элемен
Добрый день, Есть такой код: var schedules = $('&lt;div/&gt;', { 'class' : 'collapse', }).append($('&lt;table/&gt;', { ...

Получить элемент из DOM
Есть HTML: &lt;div class=&quot;moduletable_topmenu&quot;&gt; &lt;ul id=&quot;topmenu_main&quot; class=&quot;menu&quot;&gt; &lt;li&gt;&lt;a href=&quot;&quot;&gt;О компании&lt;/a&gt;&lt;/li&gt; &lt;li...

Получить элемент DOM принадлежащий двум классам одновременно?
Если написать так $(&quot;.myClass.myOtherClass&quot;) - это будет логическое &quot;или&quot;. Как сделать логическое &quot;и&quot;?:)

Передать элемент из списка SELECT
Передаю данные на почту. Как передать элемент списка в обработчик формы? &lt;select name=&quot;color&quot;&gt; &lt;option...

Как получить значение option из списка select?
Доброго времени суток! Подскажите, пожалуйста, как получить результат выбора со страницы в контроллер? Значение поля input получаю по...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru