2

选择一行时尝试从下表中获取ID。例如,jquery 应该返回:“12,14”..我下面的代码返回空字符串?

我的html:

<table id="display" width="100%">
  <thead>
      <tr>
           <th>ID</th>
           <th>first</th>
           <th>last</th>
           <th>number</th>
       </tr>
   </thead>
<tbody>
...etc...
   <tr class="selected">
      <td>12</td>
      <td>Bob</td>
      <td>Smith</td>
      <td>9999</td>
   </tr>
   <tr>
      <td>13</td>
      <td>Lee</td>
      <td>Smith</td>
      <td>8888</td>
   </tr>
   <tr class="selected">
      <td>14</td>
      <td>JJ</td>
      <td>Wolf</td>
      <td>77777</td>
   </tr>
... etc..
</table>

我的jQuery:

 var nameIDs = $('table tr.selected td:first').map(function () {
                return this.value;
            }).get().join(',');
4

2 回答 2

4

没有为td定义,value需要使用this.innerTextor this.innerHTML,也可以使用first-child代替first

现场演示

var nameIDs = $('table tr.selected td:first-child').map(function () {
    return this.innerText;
}).get().join(',');

编辑

html 也无效,您错过了所有行</td>的第二个结束。td

改变

<td>Smith<td>

<td>Smith</td>
于 2014-07-30T20:52:01.447 回答
0

此代码可以帮助您

var elems = $(".selected>td:first-child");
for(var key in elems )
  elems[key] = $(elems[key]).html();
var values = elems.join(",");

结果在字符串中values

于 2014-07-30T21:10:30.513 回答