169 похожих чатов

Можно ли для биндингов добавить конвертацию? например, если нужен инпут

для ввода 16-ричного числа с number'ом на выходе. типа:
<script lang="ts">
export let num: number
let hex: string

$: hex = num.toString(16)
$: num = parseInt(hex, 16)
</script>

<input bind:value={hex} />

но тут на циклическую зависимость ругаются аж два линтера.

или такое вообще сделать нельзя, и надо вешаться на on:change?

11 ответов

21 просмотр

<script lang="ts"> export let num: number $: hex = parseInt(num.toString(16), 16) </script> <input bind:value={hex} /> Не устроит ли такой вариант?

3bl3gamer- Автор вопроса
Eric Rovell
<script lang="ts"> export let num: number $: ...

не, так в инпуте ж будет десятичное число

3bl3gamer
не, так в инпуте ж будет десятичное число

Всё, понял, нужно же в 16 систему...)

Можно сделать это экшнами

Обычно в таких кейсах помогает дополнительная проверка в $:

3bl3gamer- Автор вопроса
Pavel 🦇 Malyshev
Обычно в таких кейсах помогает дополнительная пров...

проверка на равенство между num и hex (с конвертацией) перед каждым присваиванием? всё равно ругается на циклическую зависимость, ещё на этапе сборки

3bl3gamer
проверка на равенство между num и hex (с конвертац...

Очень хорошая идея сделать это экшеном, как подсказал Марк, советую попробовать.

3bl3gamer
проверка на равенство между num и hex (с конвертац...

посмотрел внимательнее, тут все еще проще: https://svelte.dev/repl/5cc79bd74b3e48a28a34a80914bfd01f?version=3.37.0

Pavel 🦇 Malyshev
посмотрел внимательнее, тут все еще проще: https:/...

Такой вопрос. С чем связано то, что когда мы удаляем десятичное число внутри input связь пропадает и далее если мы пишем уже другое число HEX не меняется.

3bl3gamer- Автор вопроса
Pavel 🦇 Malyshev
посмотрел внимательнее, тут все еще проще: https:/...

так тут хексовый инпут не редактируется. наверно потмоу что при изменении hex выполняется весь блок $:, а там первая строка hex = num?.toString(16); затирает только что изменившееся значение

3bl3gamer
так тут хексовый инпут не редактируется. наверно п...

ой, да. невнимательно смотрю. тогда нужно будет еще проверки впилить и кажется вариант с ивентом, который выше предложили будет более лаконичным. можно только on:change заменить на on:input и в контексте текстового поля разницы с биндингом не будет

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

Обсуждают сегодня

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Ребят в СИ можно реализовать ООП?
Николай
33
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Карта сайта