Alexey
Den
🤴👷♂️🦸♂️🧚♀️
🦜
🤴👷♂️🦸♂️🧚♀️
в документации
о, кул, нашел только с поиском по ключевым словам))
🦜
showUploadList={{showPreviewIcon: false}}
Ruslan
Andrew
Material ui
ну если чисто для модалок тянуть материал….. может проще самому сделать
Ruslan
Самому проще, а если надо быстро, можно и подключить
Solnur
Алексей
Ребят, пробую reselect и встала сразу проблема: работает polling данных. Почти каждый раз прилетают одни и те же данные - происходит rerender компонента, использующий эти данных. Пытаюсь закешировать эти данные с помощью селектора - не получается - rerender все равно происходит. Что не так в этом коде?
function getAllTickets(reducer) {
return reducer.get('tickets');
}
export const allTicketsSelector = createSelector([getAllTickets], items => items);
🦜
🦜
🤴👷♂️🦸♂️🧚♀️
а тебе что надо?
при ховере на родителя чтоб иконки вспылвали. у меня стейта нет, только если укажу его, то кнопки появятся
🦜
🦜
Dmytro
Vladimir
Кто нибудь юзает preact?
Vladimir
Как вы настриваете свою IDE под него?
Например Webstorm
Mikhail
я юзаю, так же как реакт
Mikhail
никак не настраваю ide
Vladimir
а проблемы с jsx, class, className
Vladimir
Vladimir
Вот это например
Cenator 🐈
Юзай реакт в деве, преакт компат в проде
Алексей
кто-нибудь сталкивался с проблемой в react-router-dom когда по роуту идёшь потом перегружаешь страницу и выкидывает 404 причем что редиректа нету
Vladimir
Изъеб, но спасибо
Vladimir
Юзай реакт в деве, преакт компат в проде
Vladimir
Возможно стоит задуматься об отказе преакта
Cenator 🐈
Да
Vladimir
Ну страдать, ради экономии в 30-40кб так себе
Mikhail
Tor
Где вы находите ту грань, между удобным DX и размером бандла?
Пишите на ваниле, там нет ненужного реакта, если уходить в крайности.
🦜
Mikhail
Илья
Виктор
а преакт разве не отваливается у юзеров на компах?
Дима
Default
Titov
ну его, он стремный
Вопрос по поводу использование middleware с роутером и firebase:
Есть firebase который получает авторизированного пользователя.
У меня есть роуты в отдельным файлом.
И этот список роутов рендерится в навбаре, каким образом прикрутить middleware к этим роутам? спасибо.
Vladimir
Hello world - от преакта - 10кб - gzip
Hello world от реакта - 35кб gzip
Vladimir
10кб против 110кб, и никаких страданий
Alexey
Default
Пока стрёмный
Там есть достаточно много объективных проблем и Рич прекрасно о них знает, просто даже третья версия Svelte это один гигантский todo
Default
Хотя мне, как ни странно, пока что не хватает только нормальной поддержки TS/Flow
Alexey
Solnur
Оптимизация это правильно! Но стоит ли сравнивать (да да 100кб js не равен 100кб картинке, но опять же что там в этом 100кб js) если норм либа то почему бы и нет? если, мгновениями позже мы загрузим 1000мб+ медиа и на этом фоне вся наша дрочка с размерами js теряет смысл
i
всем привет, хочу уточнить правильно ли понял. React.PureComponent от обычного отличается тем, что там меньшеисполняемого рендер кода внутри и его стоит юзать когда надо чтоб компонент просто выводил хтмл с инфой - когда внутри компеонента нет других компонентов
Alexey
Разве дешевле выйдет вместо проверки в VirtualDOM проверять каждый раз массив?
а virtual dom причем?
reselect - мемоизированные селекторы
Реакт перерисовывает компонент каждый раз, как в сторе поменялось что-то. А т.к. redux иммутабельный - любое изменение - новый объект store - перерисовка компонентов. Чтобы этого не происходило - селекторы должен проверять не ===, а deep equal своего "кусочка" стора. В принципе то же самое можно делать в shouldcomponentupdate.
Да, думаю проверить пару объектов дешевле, чем преобразовать их в dom tree.
i
или его стоит юзать в принципе для вывода статики, то бишь если компонент предполагает пропсы и состояние, то React.PureComponent уже не юзать
Alexey
Alexey
Юрий
ребят, у меня есть 2 массива в стейте, я хочу описать 2 метода, в котором каждый из массивов будет перебираться и возвращаться <li>{item}</li>
а в рендере вызвать этот метод внутри <ul></ul>
но ничего не выводиться, вопрос почему?
Alexey
Alexey
и даже если данные те же, компонент перерисуется
i
@n3r0bi0m4n там написано, что пропускает обновление пропсов для всего поддерева компонентов
i
http://prntscr.com/o4sui7
i
так... всё-таки чем пур отличается от обычного, не понимаю
i
про React.memo чётко написано что он для статики
i
а с PureComponent я до сих пор не понял, вроде написано что он тоже подразумевает статику, но с другой стороны можно и по пропсам менять результирующий рендер
i
а обычный компонент разве не так работает?
Vadim
а обычный компонент разве не так работает?
React.PureComponent похож на React.Component. Отличие заключается в том, что React.Component не реализует shouldComponentUpdate(), а React.PureComponent реализует его поверхностным сравнением пропсов и состояния.
Alexey
а обычный компонент разве не так работает?
для обычного
const a = [1,2,3];
const b = [...a];
// a !== b
для pure a === b, т.к. данные те же (поверхностно)
shouldComponentUpdate() вызывается перед рендером, когда получает новые пропсы или состояние. Значение по умолчанию равно true. Этот метод не вызывается при первом рендере или когда используется forceUpdate().
Обычный ререндерится всегда, просто меняет кусочки, которые поменялись в реальном dom
i
то бишь для обычного будет перерендер даже если новые пропсы такие же как старые?
Alexey
да
i
и у should не будет обновления дочернрх компонентов?
i
то бишь внутри него предполагаются ток компоненты со статикой?
Alexey
все компоненты - динамические
компонент со статикой это
shouldcomponentupdate(nextstate, nextprops, nextcontext) { return false; } :)
Alexey
один раз нарисуется и всё)
Alexey
либо я не правильно понял вопрос
тогда извиняюсь