我可以使用带有三列的JQuery遍历id =“tbl”的表,并在三个javascript数组中收集这个值吗?我可以使用JQuery遍历表并在三个数组中收集值吗?
2
A
回答
7
下面是一个例子
的Javascript:
$().ready(function(){
var trArray = []
$('#tbl tr').each(function(){
var tdArray = []
$(this).find('td').each(function(){
tdArray.push($(this).text())
})
trArray.push(tdArray)
})
//console.log(trArray)
for(row = 0; row < trArray.length; row++){
for(cell = 0; cell < trArray[row].length; cell++){
alert('row: '+row+', cell: '+cell+' value: '+trArray[row][cell])
}
}
})
HTML
<table id="tbl" border="1">
<tr>
<td>1</td>
<td>2</td>
<td>3</td>
</tr>
<tr>
<td>4</td>
<td>5</td>
<td>6</td>
</tr>
</table>
0
可以使用this找到第N个元素的“TR” 所以$("#tbl td").eq(2)
都可以获得3“TD”
0
这样的事情应该工作。
firstCols = new Array();
secondCols = new Array();
thirdCols = new Array();
$(function() {
$("#tbl tr").each(function(i) {
var firstChild = $(this).children().first();
firstCols[i] = firstChild.text();
secondCols[i] = firstChild.next().text();
thirdCols[i] = firstChild.next().next().text();
});
});
0
当然,您可以:
// Column-arrays
var col1 = new Array();
var col2 = new Array();
var col3 = new Array();
// Cache table
var table = $('#tbl');
// Iteratate over rows
var rows = table.find('tr');
rows.each(function() {
// Iterate over columns
var columns = this.children('td');
// Save column-values in separate arrays
col1.push(columns[0].html());
col2.push(columns[1].html());
col3.push(columns[2].html());
});
+1
这可能不起作用,因为'tr'元素不是'table'的子元素,而是'tbody'元素的子元素。 – 2011-05-30 10:24:47
+0
你是对的,找到()它是 – marsbear 2011-05-30 11:28:34
0
您可以遍历列并通过索引组织它。这不是一个语义表,但是如果添加标题/主体,请确保相应地更改选择器。
var arr = [];
$('#tbl td').each(function(){
var colId = $(this).index();
var rowId = $(this).parent().index();
if (arr[colId] == undefined) {
arr[colId] = [];
}
arr[colId][rowId] = $(this).html();
});
console.log(arr);
这里的小提琴:http://jsfiddle.net/MfxA9/
这里的HTML
<table id='tbl'>
<tr>
<td>Col 1 : Row 1</td>
<td>Col 2 : Row 1</td>
<td>Col 3 : Row 1</td>
</tr>
<tr>
<td>Col 1 : Row 2</td>
<td>Col 2 : Row 2</td>
<td>Col 3 : Row 2</td>
</tr>
<tr>
<td>Col 1 : Row 3</td>
<td>Col 2 : Row 3</td>
<td>Col 3 : Row 3</td>
</tr>
<tr>
<td>Col 1 : Row 4</td>
<td>Col 2 : Row 4</td>
<td>Col 3 : Row 4</td>
</tr>
</table>
相关问题
- 1. 我可以使用ng-repeat来遍历AngularJS中的数组吗?
- 2. 我可以使用iterable在“foreach”中一遍又一遍地遍历列表吗?
- 3. 我可以使用pdb文件来遍历第三方程序集吗?
- 4. 可以使用指针来遍历一个字符数组吗?
- 5. 如何遍历表并从三个不同的数组中收集这些字段的值?
- 6. Ruby - 遍历数组并创建一个三列x行表
- 7. 三维数组遍历
- 8. 遍历JS收集
- 9. 我可以使用ExpressJS遍历查询字符串参数吗?
- 10. jquery遍历数组
- 11. 通过遍历一个jQuery数组,并使用$ .inArray内
- 12. 遍历jquery中的数组
- 13. 遍历数组值
- 14. 使用Javascript/jQuery遍历嵌套列表并存储在数组中
- 15. 我可以收集数组中的find(\&wanted,@directories)的输出吗
- 16. 循环遍历数组并检索值
- 17. PHP遍历数组并插入键/值
- 18. jQuery中的函数可以遍历元素并显示/隐藏?
- 19. 我可以使用C++从C#BHO遍历DOM吗?
- 20. 我可以使用openmp遍历C++ 11 std :: tuple吗?
- 21. 映射两个数组...现在...我可以映射三个吗?
- 22. 你可以使用Qt foreach循环遍历每个可能的枚举值吗?
- 23. 使用jQuery遍历多个html表格
- 24. 遍历Hashmap并将值存储在变量中以供使用
- 25. jquery,遍历json数组
- 26. 遍历数组并在PHP中创建项目集合?
- 27. 在Swift中遍历可选数组?
- 28. 使用cin遍历数组
- 29. 使用变量遍历数组并显示匹配JQuery
- 30. 遍历一个PHP数组比遍历MySQLi关联数组更好吗?
示例代码,请 – Niklas 2011-05-30 10:10:44
可以呀.... – 2011-05-30 10:13:13
[?这样(http://jsfiddle.net/4tUww /) – Sylvain 2011-05-30 10:18:59