Форум программистов, компьютерный форум, киберфорум
JavaScript для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
 Аватар для skapunker
-30 / 25 / 12
Регистрация: 13.12.2013
Сообщений: 1,459

Как сэмулировать клик по ссылке в данном случае?

14.01.2023, 22:07. Показов 1248. Ответов 16
Метки js (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет! Подскажите пожалста, как сэмулировать клик по данной ссылке.
Менять код нельзя, так как это по сути костыль.

HTML5
1
2
3
4
5
<div class="free-cm-app-tape-detect__item__icon">
<a href="#">
<img src="icon.svg">
</a>
</div>
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.01.2023, 22:07
Ответы с готовыми решениями:

Клик по ссыллке и клик по ссылке с выбранным чекбоксом
Есть две ссылки, одна выступает в виде кнопки... &lt;a href=&quot;{take_new_book}&quot; class=&quot;beautifulButton margRight&quot;&gt;Naujas...

Как в данном случае x^m превратился в (x^2 - 1)^(-m) ?
Как в данном случае x^m превратился в (x^2 - 1)^(-m) ? На данный вопрос ответ не требуется, я разобрался.

Как улучшить ПК в данном случае?
Всем привет! Подскажите, пожалуйста: &quot;Что в моём ПК на данный момент является слабым звеном - чтобы можно было усилить пк?&quot; ...

16
Философ-разговорник
 Аватар для Padonak
1066 / 391 / 120
Регистрация: 20.02.2016
Сообщений: 884
Записей в блоге: 1
14.01.2023, 22:32
JavaScript
1
document.querySelector('[src="icon.svg"]').closest('a').click()
2
 Аватар для skapunker
-30 / 25 / 12
Регистрация: 13.12.2013
Сообщений: 1,459
15.01.2023, 07:51  [ТС]
Ситуация усложнилась.

Теперь нужно эмулировать этот клик каждые 3 секунды, пока в этом блоке
HTML5
1
.free-cm-app-tape-detect__container > .free-cm-app-tape-detect__item:nth-child(2) > .free-cm-app-tape-detect__content
не исчезнет символ -
0
Философ-разговорник
 Аватар для Padonak
1066 / 391 / 120
Регистрация: 20.02.2016
Сообщений: 884
Записей в блоге: 1
15.01.2023, 16:38
Непонятно как-то излагаете
0
 Аватар для skapunker
-30 / 25 / 12
Регистрация: 13.12.2013
Сообщений: 1,459
15.01.2023, 17:00  [ТС]
Цитата Сообщение от Padonak Посмотреть сообщение
Непонятно как-то излагаете
в общем вот разметка
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
<div class="app-tape-detect__container">
 
<div class="app-tape-detect__item">
<span class="app-tape-detect__label">Пол:</span>
<span class="app-tape-detect__content">-</span>
</div>
 
<div class="app-tape-detect__item">
<span class="app-tape-detect__label">Ваш возраст:</span>
<span class="app-tape-detect__content">-</span> <!--если все пройдет успешно (а может быть и не так) этот дефис исчезнет при клике по нашей ссылке, вместо него может появиться число или буквы -->
</div>
 
</div>
скрипт кликает по ссылке, о которой речь шла в начале темы
если все проходит успешно, то в коде (там где комментарий) появляется возраст.

Суть в том, чтобы скрипт кликал каждые 3 секунды по нашей ссылке, пока вместо этого дефиса не появится значение.
Если через какое то время дефис снова появляется, то скрипт снова начинает кликать.

Добавлено через 2 минуты
то что это все дичайшая дичь, я абсолютно согласен, но увы жизнь заставляет действовать именно так
0
 Аватар для klyapa
3503 / 1267 / 429
Регистрация: 24.07.2016
Сообщений: 1,890
15.01.2023, 17:23
skapunker, вот это посмотрите, может и клики не понадобятся
=> MutationObserver: наблюдатель за изменениями
0
Эксперт JSЭксперт HTML/CSS
 Аватар для krvsa
3807 / 1645 / 428
Регистрация: 14.03.2022
Сообщений: 4,091
15.01.2023, 19:04
Лучший ответ Сообщение было отмечено skapunker как решение

Решение

skapunker, предложу такой вариант...
PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<script>
document.addEventListener('DOMContentLoaded', _ => {
    const o = document.querySelector('[src="icon.svg"]').closest('a')
    o.addEventListener('click', _ => {
        console.log('ok')
    })
    let ot = '.app-tape-detect__container > .app-tape-detect__item:nth-child(2) > .app-tape-detect__content'
    ot = document.querySelector(ot)
    document.querySelector('#test').addEventListener('click', e => {
        ot.textContent = e.target.value
    })
    setTimeout(test , 3000)
    //
    function test() {
        if (ot.textContent === '-') o.click() 
        setTimeout(test , 3000)
    }
})
 
/*
$(_ => {
})
*/
</script>
</head>
<body>
 
<div id='test'>
    <button value=''>Убрать -</button>
    <button value='-'>Добавить -</button>
</div>
 
<div class="free-cm-app-tape-detect__item__icon">
    <a href="#">
        <img src="icon.svg">
    </a>
</div>
 
<div class="app-tape-detect__container">
     
    <div class="app-tape-detect__item">
        <span class="app-tape-detect__label">Пол:</span>
        <span class="app-tape-detect__content">-</span>
    </div>
     
    <div class="app-tape-detect__item">
        <span class="app-tape-detect__label">Ваш возраст:</span>
        <span class="app-tape-detect__content">-</span>
    </div>
     
</div>
 
</body>
</html>
1
 Аватар для skapunker
-30 / 25 / 12
Регистрация: 13.12.2013
Сообщений: 1,459
15.01.2023, 20:13  [ТС]
Цитата Сообщение от krvsa Посмотреть сообщение
предложу такой вариант.
там не нужны кнопки добавить и убрать, вы неправильно поняли
при клике по ссылке система сама устанавливает возраст и добавляет туда значение (или не устанавливает, если это не удалось сделать)

а повторение и для того нужно, чтобы в случае неудачи попытаться определить возраст повторно
0
Эксперт JSЭксперт HTML/CSS
 Аватар для krvsa
3807 / 1645 / 428
Регистрация: 14.03.2022
Сообщений: 4,091
15.01.2023, 20:22
Цитата Сообщение от skapunker Посмотреть сообщение
там не нужны кнопки добавить и убрать, вы неправильно поняли
Это я для тестирования...
Дабы ты воочию смог убедиться что все там на тот минус завязано.
1
 Аватар для skapunker
-30 / 25 / 12
Регистрация: 13.12.2013
Сообщений: 1,459
15.01.2023, 21:22  [ТС]
Цитата Сообщение от krvsa Посмотреть сообщение
Это я для тестирования...
все работает! алилуййа!

я только не понял, зачем из функции снова вызывать setTimeout(test , 3000)
0
Эксперт JSЭксперт HTML/CSS
 Аватар для krvsa
3807 / 1645 / 428
Регистрация: 14.03.2022
Сообщений: 4,091
16.01.2023, 10:52
Цитата Сообщение от skapunker Посмотреть сообщение
я только не понял, зачем из функции снова вызывать setTimeout(test , 3000)
Так это и есть алгоритм "следилки".
0
 Аватар для skapunker
-30 / 25 / 12
Регистрация: 13.12.2013
Сообщений: 1,459
17.01.2023, 11:16  [ТС]
Цитата Сообщение от krvsa Посмотреть сообщение
предложу такой вариант
а если эту строку
JavaScript
1
 let ot = '.app-tape-detect__container > .app-tape-detect__item:nth-child(2) > .app-tape-detect__content'
заменить на
JavaScript
1
 let ot = '.app-tape-detect__container > .app-tape-detect__item > .app-tape-detect__content'
тогда будет проверять дефисы в обоих блоках или только в первом?
0
Эксперт JSЭксперт HTML/CSS
 Аватар для krvsa
3807 / 1645 / 428
Регистрация: 14.03.2022
Сообщений: 4,091
17.01.2023, 11:33
Цитата Сообщение от skapunker Посмотреть сообщение
тогда будет проверять дефисы в обоих блоках или только в первом?
Смотря как напишешь...

Такой вариант
Цитата Сообщение от krvsa Посмотреть сообщение
JavaScript
1
ot = document.querySelector(ot)
В любом случае найдет только один, первый удовлетворяющий селектору, элемент.

А вот такой вариант
JavaScript
1
const list = document.querySelectorAll(ot)
Даст уже целую коллекцию элементов. По ней можно пройтись циклом и выполнить некие манипуляции с ее элементами...
0
 Аватар для skapunker
-30 / 25 / 12
Регистрация: 13.12.2013
Сообщений: 1,459
17.01.2023, 13:20  [ТС]
Цитата Сообщение от krvsa Посмотреть сообщение
Даст уже целую коллекцию элементов.
то есть просто добавить All для проверки всех элементов не прокатит? надо еще что то переделывать?

Добавлено через 1 час 43 минуты
В общем то я сделал так, но почему то скрипт начал выполнять клик несколько раз в секунду

JavaScript
1
2
3
4
5
6
7
8
            let list = document.querySelectorAll(ot); 
            setTimeout(test(list) , 2000);            
            function test(list) {
                for(let i=0; i<list.length; i++) {
                    if (list[i].textContent === '-') o.click();
                } 
                setTimeout(test(list) , 2000); 
            }
Подскажити, что тут не так?
0
Эксперт JSЭксперт HTML/CSS
 Аватар для krvsa
3807 / 1645 / 428
Регистрация: 14.03.2022
Сообщений: 4,091
17.01.2023, 15:20
Цитата Сообщение от skapunker Посмотреть сообщение
то есть просто добавить All для проверки всех элементов не прокатит? надо еще что то переделывать?
Все верно. Добавление "All" только выполнит выборку элементов, а вот что с ними потом делать - уже решает разработчик.
Цитата Сообщение от skapunker Посмотреть сообщение
я сделал так, но почему то скрипт начал выполнять клик несколько раз в секунду
Так сколько раз запустил - столько раз он и выполнился.

Как вариант, в цикле нужно просто определиться "нужно делать клик" или нет. И уже после цикла анализировать ситуацию.
0
 Аватар для skapunker
-30 / 25 / 12
Регистрация: 13.12.2013
Сообщений: 1,459
21.01.2023, 21:35  [ТС]
хм, сейчас подумал...
а если ссылка по которой нужно кликать будет иметь стиль display:none
тогда она будет кликаться?
0
Эксперт JSЭксперт HTML/CSS
 Аватар для krvsa
3807 / 1645 / 428
Регистрация: 14.03.2022
Сообщений: 4,091
22.01.2023, 01:45
Цитата Сообщение от skapunker Посмотреть сообщение
а если ссылка по которой нужно кликать будет иметь стиль display:none
тогда она будет кликаться?
Методам элементов все равно видно элементы или нет... Главное чтобы сами элементы были.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.01.2023, 01:45
Помогаю со студенческими работами здесь

Как обработать клик по ссылке?
Здравствуйте. Возникла проблема обработки клика на ссылку. Ссылка - это путь к файлу. Собственно, зачем это нужно? Хотелось бы, когда...

Как отловить клик по ссылке?
точнее по конкретной ссылке. Хочу повесить confirm на ссылку отвечающую за удаление страницы. Ссылки генерются автоматом, это меню. И там...

Как модифицировать в данном случае URL?
Подскажите пожалуйста как мне удалить в этом URL - ( allimages.php?sessionid=fdcevs1es5uhqi99mhvhu6f6q4&amp;p=1598 ) данные последние...

Как считать P-значения в данном случае
Имеется задача о проверке гипотезы о равенстве 0 коэфф. корреляции между двумя величинами, проверяю на модельных данных, генерирую базовый...

Как работает конструкция this в данном случае?
Народ, помогите. Отрывок кода из книги Рихтера, как тут работает конструкция this? internal class Node { ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
17
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru