1

我正在使用 jquery 尝试检索文本输入的值,但它不起作用。谁能看到我做错了什么?http://jsfiddle.net/silvajeff/4Sb8K/3/

<table id="oustandingItems">
  <tr><th>Category</th></tr>
  <tr><td><input name="mytest" /></td></tr>
  <tr><td><input name="mytest" value="123"/></td></tr>
  <tr><td><input name="mytest" /></td></tr>
  <tr><td><input name="mytest" /></td></tr>
</table>


<button id="findRow">Find Row</button>
<input type="text" id="myRow" />

$("#findRow").click(function() {   
  var tableRow = $('#oustandingItems tr:has(td input[value!=""])').prevAll().length;  
 var myValue = $('#oustandingItems input:has(td input[value!=""])').val();
  $("#myRow").val(myValue);
});
4

3 回答 3

2

您可以将选择器简化为#oustandingItems tr input[value!=""]

$("#findRow").click(function() {
  var myValue = $('#oustandingItems tr input[value!=""]').val();
  $("#myRow").val(myValue);
});

JSFiddle

于 2013-01-15T07:52:00.473 回答
0

你可以试试这个:http: //jsfiddle.net/4Sb8K/6/

$("#findRow").click(function() {   
  var myValue = $('#oustandingItems').find('input[value!=""]').val();
  $("#myRow").val(myValue);
});
于 2013-01-15T07:54:25.230 回答
0

您查找具有值的输入框的选择器是错误的。

- var myValue = $('#oustandingItems input:has(td input[value!=""])').val();

+ var myValue = $('#oustandingItems input[value!=""]').val();

顺便说一句,如果您的选择器匹配多个元素,.val() 方法仅返回第一个元素的值。如果需要遍历所有元素,请使用 .each() 方法。

于 2013-01-15T07:58:07.683 回答