Я работаю над проектом, используя Selenium (Python), где мне нужно программно заполнить форму, включающую поля ввода кредитной карты. Тем не менее, сайт предотвращает стандартные методы впрыска JavaScript от настройки значений на этих входах.
Вот входной элемент, с которым я работаю: < /p>
< /code>
А вот JavaScript, который я пытался использовать. Имейте в виду, что я попробовал кучу других решений JavaScript: < /p>
(() => {
const input = document.querySelector('input[aria-label="Name on card"]');
if (input) {
const setter = Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, 'value').set;
setter.call(input, 'Hello World');
input.dispatchEvent(new Event('input', { bubbles: true }));
input.dispatchEvent(new Event('change', { bubbles: true }));
}
})();
< /code>
Это не обновляет поле, как и ожидалось. Тем не менее, происходит что-то странное: если я активирую инспектора DOM (Ctrl+Shift+C), нажмите на элемент, а затем повторно запустите тот же фрагмент JavaScript, он работает. Просто нажимать на ввод нормально или пытаться напечатать вручную, не помогает. это имитирует реальный пользовательский ввод?
Подробнее здесь: https://stackoverflow.com/questions/795 ... ing-javasc
Не могу программно установить значение в поле ввода (поле кредитной карты), используя JavaScript - Setter не работает ⇐ Javascript
Форум по Javascript
1744512571
Anonymous
Я работаю над проектом, используя Selenium (Python), где мне нужно программно заполнить форму, включающую поля ввода кредитной карты. Тем не менее, сайт предотвращает стандартные методы впрыска JavaScript от настройки значений на этих входах.
Вот входной элемент, с которым я работаю: < /p>
< /code>
А вот JavaScript, который я пытался использовать. Имейте в виду, что я попробовал кучу других решений JavaScript: < /p>
(() => {
const input = document.querySelector('input[aria-label="Name on card"]');
if (input) {
const setter = Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, 'value').set;
setter.call(input, 'Hello World');
input.dispatchEvent(new Event('input', { bubbles: true }));
input.dispatchEvent(new Event('change', { bubbles: true }));
}
})();
< /code>
Это не обновляет поле, как и ожидалось. Тем не менее, происходит что-то странное: если я активирую инспектора DOM (Ctrl+Shift+C), нажмите на элемент, а затем повторно запустите тот же фрагмент JavaScript, он работает. Просто нажимать на ввод нормально или пытаться напечатать вручную, не помогает. это имитирует реальный пользовательский ввод?
Подробнее здесь: [url]https://stackoverflow.com/questions/79571151/cant-programmatically-set-value-in-input-field-credit-card-field-using-javasc[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия