循环遍历表行并获取行中的每个值 - 查找错误?

时间:2012-07-31 12:00:55

标签: javascript jquery html

下面我有一个简单的表格,我试图循环并获取每行中每个单元格的值<td>s

但是我收到错误,说find不存在,是的,添加了jquery。你能帮忙吗?感谢

$(document).ready(function () {
    var x = $('table tr:has(td)');
    $.each(x, function (i, v) {

        alert(
        v.find('td').eq(0).text()); + " ----" + v.find('td').eq(1).find('option:selected').val(););
    });

});

<table>
    <tbody>
        <tr>
            <th>a</th>
            <th>b</th>
        </tr>
        <tr>
            <td>test</td>
            <td>
                <select>
                    <option value="yes">yes</option>
                    <option selected="selected" value="no">no</option>
                </select>
            </td>
        </tr>
        <tr>
            <td>test</td>
            <td>
                <select>
                    <option value="yes">yes</option>
                    <option selected="selected" value="no">no</option>
                </select>
            </td>
        </tr>
        <tr>
            <td>test</td>
            <td>
                <select>
                    <option value="yes">yes</option>
                    <option selected="selected" value="no">no</option>
                </select>
            </td>
        </tr>
        <tr>
            <td>test</td>
            <td>
                <select>
                    <option value="yes">yes</option>
                    <option selected="selected" value="no">no</option>
                </select>
            </td>
        </tr>
        <tr>
            <td>test</td>
            <td>
                <select>
                    <option value="yes">yes</option>
                    <option selected="selected" value="no">no</option>
                </select>
            </td>
        </tr>
    </tbody>
</table>

2 个答案:

答案 0 :(得分:1)

v是DOM上的元素,因此您需要将其包装到$函数中以链接另一个jQuery方法:$(v).find(...)

注意:您也可以写$(this).find(...)

答案 1 :(得分:1)

$(document).ready(function () {
    $('table tr:has(td)').each(function (tr) {
        $('td', tr).each(function (td) {
          alert($(td).text());
        });
    });
});