Определите, кто запустил функцию

У меня вопрос, я не знаю, как этого добиться с помощью Javascript.

У меня есть страница, например, с двумя полями ввода, прямо сейчас я делаю "onKeyUp", вызывая функцию и передавая параметр, указывающий, кто ее вызывает.

Есть ли способ просто вызвать функцию и узнать, какое поле ее вызвало изнутри?

Пример:

<input name = "q1" id = "q1" onkeyup = "mirar('q1')" type = "text" />
<input name = "q2" id = "q2" onkeyup = "mirar('q2')" type = "text" />

Измените это на что-то вроде

<input name = "q1" id = "q1" onkeyup = "mirar()" type = "text" />
<input name = "q2" id = "q2" onkeyup = "mirar()" type = "text" />
«Есть ли способ просто вызвать функцию и узнать, какое поле ее вызвало изнутри?»
Felix Kling 29.05.2018 23:42
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
1
34
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

EventTarget должен предоставить то, что вам нужно.

function mirar()
{
    alert("caller is " + mirar.caller);
}

Или было бы приемлемо, если бы они по-прежнему передавали параметр, но тот же параметр?

<input name = "q1" id = "q1" onkeyup = "mirar(event)" type = "text" />
<input name = "q2" id = "q2" onkeyup = "mirar(event)" type = "text" />

function mirar(event) { 
    alert(event.target.nodeName);
}

Однако первый не даст вам элемент поля ввода.

Felix Kling 30.05.2018 00:59
Ответ принят как подходящий

Вы можете просто передать this, чтобы указать это в функции, чтобы узнать, из какого элемента функция фактически вызывается:

function mirar(el){
  console.info('Id:', el.id)
}
<input name = "q1" id = "q1" onkeyup = "mirar(this)" type = "text" />
<input name = "q2" id = "q2" onkeyup = "mirar(this)" type = "text" />

Другие вопросы по теме