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

Мне нужно получать текст Title-1 или Title-2 каждый раз, когда я нажимаю на соответствующий <li>. Ниже моя попытка, которая не работает.

<ul id = "playlist">
<a onclick = "loadSong(); get_text();"><li>Tilte-1</li></a>
<a onclick = "loadSong(); get_text();"><li>Title-2</li></a>
</ul>

Как я могу этого добиться?

На мой взгляд, лучшим способом было бы разместить данные в data-*, таком как data-title. в противном случае используйте e.target.textContent

Get Off My Lawn 31.01.2019 17:54
Поведение ключевого слова "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) для оценки ваших знаний,...
1
1
438
5
Перейти к ответу Данный вопрос помечен как решенный

Ответы 5

Передать текущий элемент, передав this в функцию get_text(this):

// Mocking this function.
function loadSong() {
  // Stuff
}

// Add a parameter which.
function get_text(which) {
  // Use which.innerHTML to access the content.
  console.info(which.innerHTML.trim());
}
<ul id = "playlist">
  <li><a onclick = "loadSong(); get_text(this);">Tilte-1</a></li>
  <li><a onclick = "loadSong(); get_text(this);">Title-2</a></li>
</ul>

Примечание: У вас должен быть <li> как прямой потомок <ul>, а не <a>. Я изменил его для вас.

Примечание: Другим лучшим способом является передача контента на <a> с использованием атрибутов данных HTML5. Что-то типа:

<a data-title = "Hello World">

Перед использованием textContent прочтите: Келли Нортон: innerText против textContent

Я не могу их изменить!, потому что, если я это сделаю, приписанная им ссылка будет касаться только <a>, а не <li>

Mchich 31.01.2019 18:13

@Mchich Кроме этого, это работает?

Praveen Kumar Purushothaman 31.01.2019 18:21

Любая причина для понижения?

Praveen Kumar Purushothaman 31.01.2019 18:22

Еще один хороший подход — выполнять логику JavaScript только в JavaScript.

var playlist = document.getElementById("playlist");
var playlist_items = playlist.children;

for (var i = 0; i < playlist_items.length; i++) {
	playlist_items[i].onclick = function() {
  	    console.info(this.children[0].innerText);
  	}
}
<ul id = "playlist">
<a><li>Tilte-1</li></a>
<a><li>Title-2</li></a>
</ul>

что, если я захочу что-то подобное, это будет легко, нет?

Mchich 31.01.2019 18:13

<скрипт> function myFunction() { var x = document.title; document.getElementById("демо").innerHTML = x; } </скрипт> <скрипт>

Mchich 31.01.2019 18:14

да, это будет работать очень легко!

robinvrd 01.02.2019 10:19

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

function clickHandler(e) {
  console.info(e.target.textContent);
}

document.querySelector('ul').addEventListener('click', clickHandler);
<ul id = "playlist">
  <li>Tilte-1</li>
  <li>Title-2</li>
</ul>

Причина понижения? Я хотел бы скорректировать свой ответ, если для этого была веская причина.

Tom O. 31.01.2019 18:31

<ul id = "playlist">
  <li><a onclick = "loadSong(); get_text(this);">Tilte-1</a></li>
  <li><a onclick = "loadSong(); get_text(this);">Title-2</a></li>
</ul>

<p id = "demo"></p>

<script>
function get_text(which) {
   var x = document.title;
  document.getElementById("demo").innerHTML = x;
}
</script>

что-то вроде этого

Ответ принят как подходящий

Самый простой способ:

<ul id = "playlist">
    <a href = "#" onclick = "loadSong(); get_text(this)"><li>Tilte-1</li></a>
    <a href = "#" onclick = "loadSong(); get_text(this)"><li>Title-2</li></a>
</ul>

function loadSong() {
    console.info('song');
}

function get_text(e) {
    console.info(e.innerText);
}

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