Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 08.06.2014, 11:36
Новичок на форуме
Отправить личное сообщение для arashvg Посмотреть профиль Найти все сообщения от arashvg
 
Регистрация: 08.06.2014
Сообщений: 7

Выделение ячеек таблицы
Суть вопроса в чем, есть таблица, которая состоит из двух столбцов. При клике по ячейке она изменяет цвет. Нужно, чтобы при в каждой колонке можно было бы выделить только одну ячейку.

Тоесть например был клик по ячейки номер 2, в первой колонке, она перекрасилась, потом клик по ячейки номер 5, в тойжэ колнонке, ячейка номер два возвращяет свой начальный цвет, а ячейка номер 5 перекаршивается. Тоже и с второй колонкой.

Просто перекрашивание ячейки сделал, а вот как сделать описаное выше?

Код:
<script>
 $(document).ready(function(){
    $('td').click(function () {
        $(this).toggleClass('click');
        });
    });
</script>

<style>
.click {
    background-color:green;
}
</style>

<table class="bordered">
<tr>
<td class="lc" id="id1" >Text1</td>
<td  class="rc" id="id2">Text2</td>
</tr>  
<tr>
<td class="lc" id="id3" >Text3</td>
<td  class="rc" id="id4">Text4</td>
</tr> 
<tr>
<td class="lc" id="id5" >Text5</td>
<td  class="rc" id="id6">Text6</td>
</tr> 
.....
</table>
Ответить с цитированием
  #2 (permalink)  
Старый 08.06.2014, 11:47
Новичок на форуме
Отправить личное сообщение для arashvg Посмотреть профиль Найти все сообщения от arashvg
 
Регистрация: 08.06.2014
Сообщений: 7

Подсказали такой код:

$('td').click(function () {
    $('td').not($(this).toggleClass('click')).removeClass('click');
});

Но, нюанс, клик по ячейке в первой колонке, потом клик по ячейки второй колонки, первая колонка должны остатся закрашеной, а она возвращает первоначальной цвет.

Тоесть нужно выделить дв ячейки, одна в первой колонке, вторая в другой.
Ответить с цитированием
  #3 (permalink)  
Старый 08.06.2014, 12:34
Профессор
Отправить личное сообщение для jsnb Посмотреть профиль Найти все сообщения от jsnb
 
Регистрация: 15.03.2014
Сообщений: 561

$(document).ready(function(){
  $('td').click(function () {
    var columnIndex = $(this).parent().find('td').index(this);
    var $column = $(this).parent().parent().find('td:nth-child('+ ++columnIndex +')');
    if ( $(this).hasClass('click') ) {
      $(this).removeClass('click');
    } else {
        $column.removeClass('click');
        $(this).addClass('click');
      }
  });
});
Ответить с цитированием
  #4 (permalink)  
Старый 08.06.2014, 12:34
Новичок на форуме
Отправить личное сообщение для arashvg Посмотреть профиль Найти все сообщения от arashvg
 
Регистрация: 08.06.2014
Сообщений: 7

Проблема решена, может кому-то пригодится

<script>
$(document).ready(function() {
	$('table').on('click', 'td', function () {
		var index = $(this).index();
			$('td').filter(function() {
			return $(this).index() == index;
			}).removeClass('click');
    $(this).toggleClass('click');
	});
});
</script>
Ответить с цитированием
  #5 (permalink)  
Старый 08.06.2014, 13:04
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,109

arashvg,
можно было добавить 1 строку в первоначальный вариант
<!DOCTYPE HTML>
<html>
<head>
    <title>Untitled</title>
    <meta charset="utf-8">
    <style>
        .click {
            background-color: green;
        }
    </style>
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script>
    <script>
        $(function () {
            $('td').click(function () {
                $('.' + this.className).not(this).removeClass('click');
                $(this).toggleClass('click');
            });
        })
    </script>
</head>
<body>
    <table class="bordered">
        <tr>
            <td class="lc" id="id1">Text1</td>
            <td class="rc" id="id2">Text2</td>
        </tr>
        <tr>
            <td class="lc" id="id3">Text3</td>
            <td class="rc" id="id4">Text4</td>
        </tr>
        <tr>
            <td class="lc" id="id5">Text5</td>
            <td class="rc" id="id6">Text6</td>
        </tr>
    </table>
</body>
</html>
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Управление содержимым ячеек таблицы okouser Общие вопросы Javascript 9 08.02.2015 18:53
Вопрос по ширине ячеек таблицы demoniqus Общие вопросы Javascript 4 02.02.2014 13:19
Выделение цветом ячеек таблицы guln1 Общие вопросы Javascript 0 20.12.2013 10:56
Подсветка родительских ячеек таблицы Demath Элементы интерфейса 10 11.02.2013 14:33
IE 8: баг при динамическом display=none; у ячеек таблицы SegaMega Элементы интерфейса 0 21.09.2012 06:47