这里可能是一个简单的解决方案,我自己很困惑。我有一个<select>
通过MySQL用户数据库中的数组填充。没问题。我还有一个脚本,当选择某个用户时,我可以通过AJAX用户的user_id。我的问题是将该用户ID转换为变量$ assigned_to,以包含在URL中
对不起编码是如此具体。如果需要,我可以将其全部拆分为更简化的版本。
这是我到目前为止所得到的:
<script type="text/javascript">
function showData(str)
{
if (str=="")
{
document.getElementById("showData").innerHTML="";
return;
}
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
document.getElementById("showData").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","getdata.php?assign_to="+str,true);
xmlhttp.send();
}
</script>
//
//This gets the user_id value from the `<select>` when a user selects it.
//
<?php
//
//Here is the function that displays my users:
//
function userlist()
{
echo "<select name=\"assigned_to\" onChange=\"showData(this.value)\">";
echo "<option default value=\"\">Assignee</option>";
$mysqli = new mysqli("xxx", "xxx", "xxx", "xxx");
$userlist = "SELECT * FROM users where user_level = 2";
$result = $mysqli->query($userlist);
while( $row = $result->fetch_assoc() ) {
echo "<option value=\"".$row['user_id']."\">".$row['first_name']." ".$row['last_name']."</option>";
}
echo "</select> ";
}
echo "<p>";
echo userlist();
echo "<a id=\"show\" href=\"index.php?page=overview&location=advance&assignee=\"".$assign_to."\">Assign</a></p>";
?>
<!-- The line below **will** display the correct user_id value when selected -->
<div id="showData">User Id Shows Here</div>
当选择返回时,最后一个URL变量$ assign_to是我想要$ row ['user_id']的值。
我理解实现这一切的理想方法是将表单发布到php页面并使用_POST检索所有这些变量。不幸的是,在这种情况下我需要URL中的变量。
一如既往地谢谢。
答案 0 :(得分:0)
你在这里所做的应该已经做了你想做的事情。更改选择框时,将使用当前所选的选择框值调用showData函数:
<select name=\"assigned_to\" onChange=\"showData(this.value)\">
在showData-function中,检索到的参数'str'包含该值,并将其追加到url:
xmlhttp.open("GET","getdata.php?assign_to="+str,true);
您应该在首选调试工具(firebug,chrome开发人员工具)的网络选项卡中看到它,或者您可以将其记录到控制台/提醒它
alert("getdata.php?assign_to="+str);
console.log("getdata.php?assign_to="+str);
你会发现它有效
编辑:
使用param重定向到当前页面可以这样做(即使我不明白你为什么要这样做......):
var current_url = document.location.href;
var separator = current_url.indexOf('?') === -1 ? '?' : '&';
document.location.href = current_url + separator + 'assign_to=' + str;
EDIT2:
将此功能添加到您的脚本中:
function setLinkAssignee(assignee) {
var i, newParams = [], link = document.getElementById('show'),
href = link.getAttribute('href')
linkArr = href.split('?')
params = (linkArr[1] || '').split('&');
for(i=0; i < params.length; i++) {
if(params[i].indexOf('assignee=') === -1) {
newParams.push(params[i]);
}
}
link.setAttribute('href', linkArr[0] + '?' + newParams.join('&') + '&assignee='+assignee);
}
并且如果你不想要完成ajax请求就这样调用它:
<select name=\"assigned_to\" onChange=\"setLinkAssignee(this.value)\">
在你的showData中或者像这样:
function showData(str) {
// your stuff here
setLinkAssignee(str);