我有使用 jquery 通过外部 php 页面获取 mysql 数据的表单。
该脚本本质上是输入字段的自动完成。问题是我在循环中有输入字段,字段ID由循环中的计数器'$ i'确定。
因此,我想将输入框的用户输入值与计数器值“$i”一起传递给 javascript,以便 javascript 可以将结果返回到循环中的正确输入框。
我希望这是有道理的。
单个输入框的原始代码和工作代码如下:
Javascript
<script type="text/javascript">
function lookup(inputString) {
if(inputString.length == 0) {
// Hide the suggestion box.
$('#suggestions').hide();
} else {
$.post("autocompleteperson.php", {queryString: ""+inputString+""}, function(data){
if(data.length >0) {
$('#suggestions').show();
$('#autoSuggestionsList').html(data);
}
});
}
} // lookup
function fill(thisValue) {
$('#inputString').val(thisValue);
setTimeout("$('#suggestions').hide();", 200);
}
</script>
HTML
<div>
<input type="text" size="30" value="" id="inputString" onkeyup="lookup(this.value);" onblur="fill();" />
</div>
<div class="suggestionsBox" id="suggestions" style="display: none;">
<img src="upArrow.png" style="position: relative; top: -12px; left: 20px;" alt="upArrow" />
<div class="suggestionList" id="autoSuggestionsList">
</div>
</div>
所以我想做的是将行号($i)也传递给javascript,以便它将值返回到正确的输入框。我在这方面的基本尝试如下[对我缺乏 javascript 技能表示歉意:-)]
Javascript
<script type="text/javascript">
function lookup(rownumber, inputString) {
if(inputString.length == 0) {
// Hide the suggestion box.
$('#suggestions').hide();
} else {
$.post("autocompleteperson.php", {queryString: ""+(inputString+rownumber)+""}, function(data){
if(data.length >0) {
$('#suggestions').show();
$('#autoSuggestionsList').html(data);
}
});
}
} // lookup
function fill(thisValue) {
$('#inputString'+'rownumber').val(thisValue);
setTimeout("$('#suggestions').hide();", 200);
}
</script>
PHP/HTML
<table>
<? for ( $i = 1; $i <=50; $i++ ) { ?>
<tr>
<td>
<div>
<input type="text" size="30" value="" id="inputString<? echo $i; ?>" onkeyup="lookup(<? echo $i; ?>,this.value);" onblur="fill();" />
</div>
<div class="suggestionsBox" id="suggestions" style="display: none;">
<img src="upArrow.png" style="position: relative; top: -12px; left: 20px;" alt="upArrow" />
<div class="suggestionList" id="autoSuggestionsList">
</div>
</div>
</td>
</tr>
<? } ?>
</table>
问题的第二部分是让 div 建议框也出现在正确的位置。这同样适用于我希望建议框的名称附加行号“$i”的情况。
任何帮助,将不胜感激。
亲切的问候,
更新代码
javascript
<script type="text/javascript">
function lookup(inputString) {
if(inputString.length == 0) {
// Hide the suggestion box.
$('#suggestions').hide();
} else {
$.post("autocompleteperson.php", {queryString: ""+inputString+""}, function(data){
if(data.length >0) {
$('#suggestions').show();
$('#autoSuggestionsList').html(data);
}
});
}
} // lookup
function fill(rownumber, thisValue) { // add the rownumber as a parameter
$('#inputString'+rownumber).val(thisValue); // remove the quotation marks
setTimeout("$('#suggestions').hide();", 200);
}
</script>
HTML/PHP
<table>
<?
for ( $i = 1; $i <=50; $i++ ) {
?>
<tr>
<td> Job <? echo $i; ?></td>
<td>
<SELECT NAME=job<? echo $i; ?> id=job<? echo $i; ?> style="width:150px;border: 1px solid #2608c3;color:red">
<OPTION VALUE=0 ></option>
<option>
<?=$optionjobs?>
</option>
</SELECT>
</td>
<td> Person </td>
<td>
<div>
<input type="text" size="30" value="" id="inputString<? echo $i; ?>" onkeyup="lookup(<? echo $i; ?>,this.value);" onblur="fill(<? echo $i; ?>,this.value);" />
</div>
<div class="suggestionsBox" id="suggestions" style="display: none;">
<img src="upArrow.png" style="position: relative; top: -12px; left: 20px;" alt="upArrow" />
<div class="suggestionList" id="autoSuggestionsList">
</div>
</div>
</td>
</tr>
<?
}
?>
</table>