如何拆分jquery数组

时间:2011-11-27 08:57:12

标签: javascript jquery arrays html-table

我有一个表,我需要为每一行(在数组中)获取值,例如: [{1,'test'}, {2,'another test'}, {3, 'nothing'}],但我唯一能得到的是: ["1 test", "2 another test","3 nothing"]。我需要通过ajax将这些值作为json对象发送...并创建另一个表 - 因此我需要一个值数组...

var table = $("table");
var rowsAll = table.find("tbody tr");
rowsAll.each(function(i,l) {
    var rows = [];
    $(this).each(function(t,l){
    rows[rows.length] = cells[t]= $(this).text();
    return rows; //returns rows, but I need cells of each row
    }).serialize();//or get()
});

html是这样的:

<table id="deal">
<thead>
    <tr>
        <th> num </th>
        <th> string </th>
    </tr>
</thead>
<tbody>
    <tr> <td> 1 </td> <td> test </td> </tr>
    <tr> <td> 2 </td> <td> another test </td> </tr>
    <tr> <td> 3 </td> <td> nothing </td> </tr>
</tbody>
</table>

我真的需要帮助...

1 个答案:

答案 0 :(得分:3)

这种形式的数据毫无意义,因为用javascript很难阅读:

[{1,'test'}, {2,'another test'}, {3, 'nothing'}]

我会假设你想要的是这个:

{"1": "test", "2": "another test", "3": "nothing"}

要获得第二个表单,您可以使用以下代码:

var results = {};
$("#deal tbody tr").each(function() {
    var cols = $(this).find("td");
    results[$.trim(cols.eq(0).text())] = $.trim(cols.eq(1).text());
});

这里的工作示例:http://jsfiddle.net/jfriend00/WjgrC/