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

Всем привет Делаю поле ввода с форматированием на 3 версии. Форматирование

работает, но возникло два вопроса
1. Почему не сохраняется введённое значение?
2. Почему изменение значения в компоненте не доходит до основного приложения?

https://codepen.io/sm1thana/pen/dyOwwEB

10 ответов

9 просмотров
Meow- Автор вопроса

Всем ещё раз привет. Так и не добил вчера. Оба косяка исправляются если я меняю текущий :value на v-model. Но как тогда форматировать видимое значение при потере фокуса? Копать в сторону computed get/set?

Meow- Автор вопроса
Meow- Автор вопроса
Vladimir Voytenko ️
да

Не подскажите почему тогда в компоненте этого примера вариант с аналогичным :value работает на инпуте? https://codepen.io/scorch/pen/oZLLbv Beeaking в третьей версии?

Meow- Автор вопроса
Meow- Автор вопроса
Андрей Полевой
Ну можно директиву сделать...

А как она может помочь? С помощью этой инструкции https://v3.vuejs.org/guide/component-basics.html#using-v-model-on-components я связал значение кастомного input с общим приложением через computed get/set и форматирую число при change, что совпадает с blur. https://codepen.io/sm1thana/pen/dyOwwEB Но как добавить форматирование (удаление пробелов) при фокусе? Никогда ещё не чувствовал себя таким тупым))

Meow
А как она может помочь? С помощью этой инструкции...

function onInput (mobile, mask, event) { if (!event.isTrusted) return const target = event.target const value = formatValue(target.value, mobile) target.value = masker(value, '+###########') target.dispatchEvent(new Event('input', { bubbles: true, cancelable: true, composed: true })) Vue.nextTick(() => { target.value = masker(value, mask) }) } function onBlur (mobile, mask, event) { const target = event.target const value = formatValue(target.value, mobile) Vue.nextTick(() => { target.value = masker(value, mask) }) } export default { bind (el, binding) { const inputNode = el.querySelector('input') if (!inputNode) throw new Error('v-phone directive required input Node') const mobile = binding.modifiers.mobile const value = formatValue(inputNode.value, mobile) const mask = binding.value || '' inputNode.setAttribute('type', 'tel') inputNode.setAttribute('inputmode', 'tel') inputNode.value = masker(value, mask) const inputHandler = onInput.bind(null, mobile, mask) const blurHandler = onBlur.bind(null, mobile, mask) inputNode.addEventListener('input', inputHandler) inputNode.addEventListener('blur', blurHandler) inputNode.addEventListener('focus', blurHandler) }, componentUpdated (el, binding) { const inputNode = el.querySelector('input') Vue.nextTick(() => { const mobile = binding.modifiers.mobile const value = formatValue(inputNode.value, mobile) const mask = binding.value || '' inputNode.value = masker(value, mask) }) } }

Meow- Автор вопроса

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
22
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Карта сайта