使用 javascript 定位 table 内的所有标签
Target all the label inside a table using javascript
我有以下设置。我在这里尝试添加自定义单选框和复选框。
Array.from(document.querySelectorAll("tr")).forEach((tr,index)=>{
var mark=document.createElement("span");
Array.from(tr.querySelectorAll("input")).forEach((inp,index1)=>{
if(inp.type=="radio"){
mark.classList.add("dotmark");
inp.parentNode.appendChild(mark);
}
else{
mark.classList.add("checkmark");
inp.parentNode.appendChild(mark);//instead append in to the next td's label tag
}
})
})
span{
width:20px;
height:20px;
background:#ccc;
display:inline-block;
}
<table id="tab1" class="table labelCustom">
<tbody>
<tr><td><input type='radio' id='one' name='name'></td><td><label for='one'>example</label></td></tr>
<tr><td><input type='radio' id='two' name='name'></td><td><label for='two'>example</label></td></tr>
<tr><td><input type='radio' id='three' name='name'></td><td><label for='three'>example</label></td></tr>
</tbody>
</table>
我想将动态创建的 span 元素插入到 label 标签中。现在它将它插入到输入 td 中。
注意:span 元素的 class 取决于输入类型。
使用
inp.parentNode.nextElementSibling.querySelector('label')
而不仅仅是
inp.parentNode
Array.from(document.querySelectorAll("tr")).forEach((tr,index)=>{
var mark=document.createElement("span");
Array.from(tr.querySelectorAll("input")).forEach((inp,index1)=>{
if(inp.type=="radio"){
mark.classList.add("dotmark");
inp.parentNode.nextElementSibling.querySelector('label').appendChild(mark);
}
else{
mark.classList.add("checkmark");
inp.parentNode.nextElementSibling.querySelector('label').appendChild(mark);
}
})
})
span{
width:20px;
height:20px;
background:#ccc;
display:inline-block;
}
<table id="tab1" class="table labelCustom">
<tbody>
<tr><td><input type='radio' id='one' name='name'></td><td><label for='one'>example</label></td></tr>
<tr><td><input type='radio' id='two' name='name'></td><td><label for='two'>example</label></td></tr>
<tr><td><input type='radio' id='three' name='name'></td><td><label for='three'>example</label></td></tr>
</tbody>
</table>
其中一种方法如下:
Array.from(document.querySelectorAll("tr")).forEach((tr, index) => {
var mark = document.createElement("span");
Array.from(tr.querySelectorAll("input")).forEach((inp, index1) => {
// caching the <label> element for readability:
let label = inp.parentNode.nextElementSibling.querySelector('label');
// adding the class-name based on the result of the ternary operator,
// if the input.type is equal to 'radio' we return the class-name of
// 'dotmark', otherwise we return 'checkmark':
mark.classList.add(inp.type === 'radio' ? 'dotmark' : 'checkmark');
// appending the element held within the 'mark' variable:
label.appendChild(mark);
})
})
span {
width: 20px;
height: 20px;
background: #ccc;
display: inline-block;
}
span.dotmark {
background-color: limegreen;
}
span.checkmark {
background-color: #f90;
}
<table id="tab1" class="table labelCustom">
<tbody>
<tr>
<td><input type='radio' id='one' name='name'></td>
<td><label for='one'>example</label></td>
</tr>
<tr>
<td><input type='radio' id='two' name='name'></td>
<td><label for='two'>example</label></td>
</tr>
<tr>
<td><input type='radio' id='three' name='name'></td>
<td><label for='three'>example</label></td>
</tr>
<tr>
<td><input type='checkbox' id='four' name='differentName'></td>
<td><label for='four'>example</label></td>
</tr>
</tbody>
</table>
作为附录,从 OP 的评论到问题:
I tried nextSibling
but it does't worked but nextSiblingElement
worked.
两者之间的区别在于nextSibling
returns任何兄弟节点,无论是文本节点、元素节点还是任何其他节点,而nextElementSibling
,顾名思义, returns 下一个也是元素节点的兄弟。
参考文献:
您不需要嵌套循环,一次在 tr 上,然后在输入上,因为每个 tr 中只有一个输入和标签,所以您可以将它们组合成单个查询,如 tr input
。而且,您不需要使用 Array.from
,因为 querySelectorAll
returns NodeList
已经具有 forEach
功能。
document.querySelectorAll('tr input').forEach(input => {
const span = document.createElement('span')
span.classList.add(input.type === 'radio' ? 'dotmark' : 'checkmark')
input.parentNode.nextElementSibling.appendChild(span)
})
我有以下设置。我在这里尝试添加自定义单选框和复选框。
Array.from(document.querySelectorAll("tr")).forEach((tr,index)=>{
var mark=document.createElement("span");
Array.from(tr.querySelectorAll("input")).forEach((inp,index1)=>{
if(inp.type=="radio"){
mark.classList.add("dotmark");
inp.parentNode.appendChild(mark);
}
else{
mark.classList.add("checkmark");
inp.parentNode.appendChild(mark);//instead append in to the next td's label tag
}
})
})
span{
width:20px;
height:20px;
background:#ccc;
display:inline-block;
}
<table id="tab1" class="table labelCustom">
<tbody>
<tr><td><input type='radio' id='one' name='name'></td><td><label for='one'>example</label></td></tr>
<tr><td><input type='radio' id='two' name='name'></td><td><label for='two'>example</label></td></tr>
<tr><td><input type='radio' id='three' name='name'></td><td><label for='three'>example</label></td></tr>
</tbody>
</table>
我想将动态创建的 span 元素插入到 label 标签中。现在它将它插入到输入 td 中。
注意:span 元素的 class 取决于输入类型。
使用
inp.parentNode.nextElementSibling.querySelector('label')
而不仅仅是
inp.parentNode
Array.from(document.querySelectorAll("tr")).forEach((tr,index)=>{
var mark=document.createElement("span");
Array.from(tr.querySelectorAll("input")).forEach((inp,index1)=>{
if(inp.type=="radio"){
mark.classList.add("dotmark");
inp.parentNode.nextElementSibling.querySelector('label').appendChild(mark);
}
else{
mark.classList.add("checkmark");
inp.parentNode.nextElementSibling.querySelector('label').appendChild(mark);
}
})
})
span{
width:20px;
height:20px;
background:#ccc;
display:inline-block;
}
<table id="tab1" class="table labelCustom">
<tbody>
<tr><td><input type='radio' id='one' name='name'></td><td><label for='one'>example</label></td></tr>
<tr><td><input type='radio' id='two' name='name'></td><td><label for='two'>example</label></td></tr>
<tr><td><input type='radio' id='three' name='name'></td><td><label for='three'>example</label></td></tr>
</tbody>
</table>
其中一种方法如下:
Array.from(document.querySelectorAll("tr")).forEach((tr, index) => {
var mark = document.createElement("span");
Array.from(tr.querySelectorAll("input")).forEach((inp, index1) => {
// caching the <label> element for readability:
let label = inp.parentNode.nextElementSibling.querySelector('label');
// adding the class-name based on the result of the ternary operator,
// if the input.type is equal to 'radio' we return the class-name of
// 'dotmark', otherwise we return 'checkmark':
mark.classList.add(inp.type === 'radio' ? 'dotmark' : 'checkmark');
// appending the element held within the 'mark' variable:
label.appendChild(mark);
})
})
span {
width: 20px;
height: 20px;
background: #ccc;
display: inline-block;
}
span.dotmark {
background-color: limegreen;
}
span.checkmark {
background-color: #f90;
}
<table id="tab1" class="table labelCustom">
<tbody>
<tr>
<td><input type='radio' id='one' name='name'></td>
<td><label for='one'>example</label></td>
</tr>
<tr>
<td><input type='radio' id='two' name='name'></td>
<td><label for='two'>example</label></td>
</tr>
<tr>
<td><input type='radio' id='three' name='name'></td>
<td><label for='three'>example</label></td>
</tr>
<tr>
<td><input type='checkbox' id='four' name='differentName'></td>
<td><label for='four'>example</label></td>
</tr>
</tbody>
</table>
作为附录,从 OP 的评论到问题:
I tried
nextSibling
but it does't worked butnextSiblingElement
worked.
两者之间的区别在于nextSibling
returns任何兄弟节点,无论是文本节点、元素节点还是任何其他节点,而nextElementSibling
,顾名思义, returns 下一个也是元素节点的兄弟。
参考文献:
您不需要嵌套循环,一次在 tr 上,然后在输入上,因为每个 tr 中只有一个输入和标签,所以您可以将它们组合成单个查询,如 tr input
。而且,您不需要使用 Array.from
,因为 querySelectorAll
returns NodeList
已经具有 forEach
功能。
document.querySelectorAll('tr input').forEach(input => {
const span = document.createElement('span')
span.classList.add(input.type === 'radio' ? 'dotmark' : 'checkmark')
input.parentNode.nextElementSibling.appendChild(span)
})