конечно. Самый первый, пожалуй.
Child.svelte
<div on:click={() => dispatch('click')}>Hey</div>
<button on:*>click</button>
Parent.svelte
<Child on:click={() => console.log('что я такое?')} />
well known эвенты можно зпдокуиенировать как это сделано в реакте
в чем проблема?, в обоих случаях евент объект прилетает, дальше можешь его внутренновсти проверить, а чаще всего достаточно самого события
То есть мне в родителе надо знать, что ивент click у ребёнка может быть не только клик от дома, но и клик от дива? Разве это не нарушение инкапсуляции компонентов?
А если вместо on:* будет click? Т.е. по вашему инеапсуляция и сейчас нарушена
нет, достаточно знать что это клик и использовать
Проблема on:* в том, что ты не знаешь, к чему родитель подсоединится. Одно дело, когда у тебя есть очевидный dispatch('click'), другое — когда у тебя на все on:* будет навешиваться листенер от родителя, ну и ты там уже в родителе проводи тысячу проверок, чтобы убедиться, что у тебя пришло нормальное событие, а не мусор какой-то.
вопрос документирования интерфейса ребенка
Как можно задокументировать такую фигню? CustomEvent<void> | Event<any>? Если у тебя любая подписка может улететь в любой элемент, который может зафайрить его, а может и нет — это же дичара какая-то.
ты пишешь ребёнка не делай дичь и все будет ок, либо читай документацию к ребёнку если не ты его писал и решай использовать его или нет. Точно также можно один пропс на тысячу внутренних элементов навесить и говорить что можно сделать дичь
Так форвард всего — это и есть дичь же. Опять же, у тебя любой ивент может быть как кастомным, так и от дома, и чтобы отделить одно от другого тебе надо знать всё про состав ребёнка. В реакте ты передаёшь пропс, скажем, onClick: (e: EventHandler<MouseEvent, HTMLButtonElement>) => void, ну и его ни на что, кроме кнопки не навесишь, никакой ивент, кроме клика и прочих не передашь. С on:* у тебя реальная сигнатура — Event<HTMLElement> | CustomEvent. И как ты ни напишешь ребёнка, лучше не получится.
я создаю хэндлеры на Element или HtmlElement потому что давать знания о внутренних элементах наверх это неправильно и это рефакторить проще
Ну ладно, неважно, какой элемент. Важно, какое событие :)
ты говоришь проблемы конкретной реализации через on:* и даже в этой реализации они решаемы
Обсуждают сегодня