0

おそらくここでの簡単な解決策ですが、私は自分自身を混乱させています。<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>&nbsp;";
}
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 に変数が必要です。

いつもありがとう。

4

1 に答える 1

0

あなたがここでやっていることは、すでにあなたがやりたいことをしているはずです。選択ボックスが変更されると、現在選択されている選択ボックスの値で showData 関数が呼び出されます。

<select name=\"assigned_to\" onChange=\"showData(this.value)\">

showData 関数では、取得した引数「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);

そして、あなたはそれが機能するのを見るでしょう

編集:

パラメータを使用した現在のページへのリダイレクトは、そのように行うことができます(なぜあなたがそれをしたいのか理解できなくても...):

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);
于 2013-02-20T20:49:12.263 に答える