Я хочу, чтобы в консоли регистрировалась только нажатая кнопка, независимо от того, добавлена ли кнопка недавно или уже присутствует на странице.
Я хочу, чтобы событие нажатия было прикреплено ко всем присутствующим кнопкам, и в консоли должна регистрироваться только та кнопка, которая была фактически нажата.
Однако при нажатии указанной кнопки все экземпляры (все введенные кнопки), присутствующие в страница регистрируется в консоли.
Приведенный ниже код является частью content.js расширения Chrome, находящегося в стадии разработки.
const observer = new MutationObserver(function (mutationsList) {
mutationsList.forEach(mutation => {
if (mutation.type === "childList") {
const toolBarDivs = document.querySelectorAll('div[aria-label*="replies"]')
toolBarDivs.forEach(toolBarDiv => {
if (!toolBarDiv.dataset.siblingInjected) {
try {
const newDiv = document.createElement("div")
newDiv.classList.add("css-175oi2r", "r-18u37iz", "r-1h0z5md", "r-13awgt0", "copy-paste-button")
newDiv.innerHTML = `
`
toolBarDiv.insertBefore(newDiv, toolBarDiv.children[3] || null)
toolBarDiv.dataset.siblingInjected = "true"
} catch (error) {
console.error("Error injecting button:", error)
}
}
})
}
})
const allButtons = document.querySelectorAll('button[data-testid="copypaste"]')
allButtons.forEach(button => {
button.addEventListener("click", event => {
console.log("Button clicked:", event.target)
})
})
})
observer.observe(document.body, { childList: true, subtree: true })
Позже
Я попробовал это (внешняя логика наблюдателя мутаций) тоже не сработало—
document.body.addEventListener('click', function(event) {
if (event.target.tagName === 'BUTTON' && event.target.hasAttribute('data-testid') && event.target.getAttribute('data-testid') === 'copypaste') {
console.log('Button clicked:', event.target);
}
});
Подробнее здесь: https://stackoverflow.com/questions/793 ... content-js
Кнопка «Записать только нажатие» в консоли | Расширение Chrome content.js ⇐ Javascript
Форум по Javascript
1736564570
Anonymous
Я хочу, чтобы в консоли регистрировалась только нажатая кнопка, независимо от того, добавлена ли кнопка недавно или уже присутствует на странице.
Я хочу, чтобы событие нажатия было прикреплено ко всем присутствующим кнопкам, и в консоли должна регистрироваться только та кнопка, которая была фактически нажата.
Однако при нажатии указанной кнопки все экземпляры (все введенные кнопки), присутствующие в страница регистрируется в консоли.
Приведенный ниже код является частью content.js расширения Chrome, находящегося в стадии разработки.
const observer = new MutationObserver(function (mutationsList) {
mutationsList.forEach(mutation => {
if (mutation.type === "childList") {
const toolBarDivs = document.querySelectorAll('div[aria-label*="replies"]')
toolBarDivs.forEach(toolBarDiv => {
if (!toolBarDiv.dataset.siblingInjected) {
try {
const newDiv = document.createElement("div")
newDiv.classList.add("css-175oi2r", "r-18u37iz", "r-1h0z5md", "r-13awgt0", "copy-paste-button")
newDiv.innerHTML = `
`
toolBarDiv.insertBefore(newDiv, toolBarDiv.children[3] || null)
toolBarDiv.dataset.siblingInjected = "true"
} catch (error) {
console.error("Error injecting button:", error)
}
}
})
}
})
const allButtons = document.querySelectorAll('button[data-testid="copypaste"]')
allButtons.forEach(button => {
button.addEventListener("click", event => {
console.log("Button clicked:", event.target)
})
})
})
observer.observe(document.body, { childList: true, subtree: true })
Позже
Я попробовал это (внешняя логика наблюдателя мутаций) тоже не сработало—
document.body.addEventListener('click', function(event) {
if (event.target.tagName === 'BUTTON' && event.target.hasAttribute('data-testid') && event.target.getAttribute('data-testid') === 'copypaste') {
console.log('Button clicked:', event.target);
}
});
Подробнее здесь: [url]https://stackoverflow.com/questions/79347465/log-only-clicked-button-in-console-chrome-extension-content-js[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия