我想通過使用選擇框對與選定元素共享相同3個數據值的所有元素着色。它只適用於第一個選擇,但不適用於併發的。在我的循環控制檯不顯示我期望它做什麼?我必須錯過習慣於Jquery本身的東西。使用選擇框突出顯示錶格元素 - jquery
這裏是JS:
function setColor(){
$('input').on('click', function(){
var src, // packet source
dst,
proto;//
var $selectedRow = $("tr[class='selectedrow']"); // get selected row
color = $(this).val(); // grab selected color from radio button
console.log(color);
$tdelements = $selectedRow.children(); //get td elements of selected row
src = $tdelements.eq(2).text(); // grab source
dst = $tdelements.eq(3).text(); // grab destination
proto = $tdelements.eq(4).text(); // grab protocol
var $tr = $('tr'); // grab entire <tr> of document.
console.log($tr.eq(0).children());
// loop through individual <tr> elements and compare fields with the filter.
for(var i=0; i < $tr.length; i++){
$tdelements = $tr.eq(i).children(); // grab elements of the ith tr element
console.log($tdelements.eq(i));
if($tdelements.eq(2).text() === src && $tdelements.eq(3).text() === dst && $tdelements.eq(4).text() === proto){
$tr.eq(i).removeClass(color);
$tr.eq(i).addClass(color);
}
}
});
}
// Dom Ready
$(document).ready(function(){
$('tbody').on('click', 'tr', function(){
$('tr').removeClass('selectedrow');
$(this).addClass('selectedrow') ;
});
setColor();
});
這裏有一個小提琴:https://jsfiddle.net/senpaifiddler/ztd1Ltux/
我想,首先需要正確地刪除 「顏色」 類。看看https://jsfiddle.net/sL0uLuvb/。第二個是 - 你定義var'color'作爲單選按鈕的值,然後你這麼做:'$ tr.eq(i).removeClass(color);'但是這個'tr'可能有另一種顏色,它與選擇的按鈕不同顏色。 – Banzay
我不想在用戶點擊桌子時移除顏色。當我從收音機框中選擇不同的顏色時,我想要改變當前的顏色。這基本上是這裏的問題。 – IskandarG