Задать вопрос

Как присвоить класс пустой ячейке?

Как присвоить класс ячейке, в которой пусто или есть один пробел?

<table cellspasing=0>
    <tr>
      <td>Text</td>
      <td>Text</td>
    </tr>
    <tr>
      <td></td>
      <td> </td> 
    </tr>
    <tr>
      <td>Text</td>
      <td>Text</td>
    </tr>
  </table>

table {
  border-collapse: collapse;
}
td {
  border: solid 1px #ccc;
  padding: 1rem;
}
td.active {
  background: #ccc;
}

let cell = document.querySelectorAll('td');

function addColor(str) {
  if (cell.length === 1 || cell === "" || cell === " ") {
    cell.classList.add('active');
  } else {
    console.log('No!')
  }
}
addColor();
  • Вопрос задан
  • 119 просмотров
Подписаться 2 Простой Комментировать
Решения вопроса 2
0xD34F
@0xD34F Куратор тега JavaScript
Где и какой класс будем добавлять:

const table = document.querySelector('здесь селектор вашей таблицы');
const className = 'active';

Добавляем:

table.querySelectorAll('tbody td').forEach(td => {
  td.classList.toggle(className, !td.textContent.trim());
});

или

for (const { rows } of table.tBodies) {
  for (const { cells } of rows) {
    for (const td of cells) {
      if (/^\s*$/.test(td.innerText)) {
        td.classList.add(className);
      }
    }
  }
}
Ответ написан
MrDecoy
@MrDecoy Куратор тега JavaScript
Верставший фронтендер
эм..
ладно. Начнём с простого.
Если бы не пустой пробел, то можно было бы через css решить с помощью псевдоселектора :empty.
По поводу js кода, а что Вы проверяете в условии? Может ли html коллекция быть пустой строкой или строкой с пробелом?

let cells = document.querySelectorAll('td');
cells.forEach( cell => {
 if (!cell.textContent.trim()) { // если содержимое ячейки состоит только из пробелов или пустая строка, то добавляем класс active
    cell.classList.add('active')
  }
})
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
Rocket Смоленск
от 80 000 до 130 000 ₽
div. Ставрополь
от 40 000 до 90 000 ₽
Wanted. Санкт-Петербург
До 220 000 ₽
18 дек. 2024, в 11:03
5000 руб./за проект
18 дек. 2024, в 10:44
130000 руб./за проект
18 дек. 2024, в 10:02
7000 руб./за проект