我正在处理一个表单,用户可以从A - Z中选择一个字母,以选择用户名以该字母开头的用户列表。
我想要做的是当用户点击一个字母时,会调用一个php脚本来执行数据库查询,该查询会提取以所点击的字母开头的任何用户名。
我发现此页面已经启动了我http://openenergymonitor.org/emon/node/107以及这个更接近我想要做的Simple Ajax Jquery script- How can I get information for each of the rows in the table?
我想要对返回的结果做什么将它们放在SELECT列表中,当用户单击另一个字母时,该列表内容将替换为新的查询结果。
我不确定如何以及如果可能将这封信传递给php脚本,以便我可以在数据库中搜索以该字母开头的用户名。
编辑:我希望它有所改进,但我得到了Ajax错误:ParseError到目前为止这是我的代码
<div>
<ul>
<li class="alphabets" id="All">All</li>
<li class="alphabets" id="A">A</li>
<li class="alphabets" id="B">B</li>
<li class="alphabets" id="C">C</li>
<li class="alphabets" id="D">D</li>
</ul>
</div>
<div id="recipients">
$(document).ready(function(){
$("li.alphabets").click(function(){
var the_letter = $(this).text();
alert(the_letter);
$.ajax({
url: 'php/selectuser.php', type: 'GET', data: {'letter':the_letter}, dataType: 'json', success: function(rows) {
var options = '';
for (var i in rows) {
var row = rows[i];
var id = row[0];
var vname = row[1];
options += '<option value="' + id + '">' + vname + '</option>';
}
$("#userlist").html(options);
}
});
});
});
<select id="userslist" name="recipients" size="5">
</select>
</div>
答案 0 :(得分:2)
jQuery的.ajax()方法有一个名为 data 的参数,它允许你传递变量:
// Get letter from SELECT element
the_letter = $("#myselect").val();
$.ajax({
url: 'somepath/to/my/script.php',
type: 'GET',
data: {'letter':the_letter}
});
它将它作为GET参数传递,可以在PHP脚本中轻松地转换为:
$letter = $_GET['letter'];