获取PHP的选定选项
我试图将所选选项的值输入PHP,以便在查询中使用它。 但是它不断返回:null 我的代码:获取PHP的选定选项,php,javascript,jquery,json,Php,Javascript,Jquery,Json,我试图将所选选项的值输入PHP,以便在查询中使用它。 但是它不断返回:null 我的代码: <form onsubmit="getAlles()" method = "get"> <select name="optionsDrop" id = "optionsDrop" class="buttons"> </select> <input name="submitbutton" type="submit" value="submi
<form onsubmit="getAlles()" method = "get">
<select name="optionsDrop" id = "optionsDrop" class="buttons">
</select>
<input name="submitbutton" type="submit" value="submit" onclick = 'refresh()' />
</form>
Javascript:
window.onload= function getAlles()
{
$.getJSON('js/getVoorraad.php', function (data) {
refresh('#voorraadTable', data);
});
function refresh (tbBodyId, data) {
var i, j;
arrHTML = [];
console.log(data);
for (i = 0; i < data.length; i++) {
arrHTML.push('<tr>');
for (j= 0; j < data[i].length; j++) {
arrHTML.push('<td>' + data[i][j] + '</td>');
}
arrHTML.push('<td>' + "<input type = 'number' value = '1' min = '1' style=\"width: 40px;\" onKeyUp=\"this.style.width = Math.max(40,this.value.length*13)+'px';\"></input>" + '</td>');
arrHTML.push('<td>' + "<button class='but' onClick = 'replyClick(this.id)'>Voeg toe</button>" + '</td>');
arrHTML.push('</tr>');
}
$(tbBodyId).html(arrHTML.join(''));
}
}
这些选项是从数据库中插入的。
我想做的是:从选择框中选择一个选项,然后将其提供给PHP。然后将所选选项插入SQL中的WHERE语句
PHP代码:
<?php
header('Content-type: application/json');
$selectedoption = $_GET['optionsDrop'];
var_dump($_GET);
var_dump($selectedoption);
$accdbFilename = "C:\Users\Me/Proftaak DBB.accdb";
$connection = odbc_connect("Driver={Microsoft Access Driver (*.mdb, *.accdb)};Dbq=$accdbFilename", "", "");
$qFormat = <<<EOQ
select l.Naam, ac.catomschrijving, Aantal
from voorraad vo, locatie l, artikelcategorie ac
where vo.typeNr = ac.typeNr
and l.locatieNr = vo.locatieNr
and l.Naam = '%s'
EOQ;
var_dump($qFormat);
$query = sprintf($qFormat, $selectedoption);
var_dump($query);
$result = odbc_exec($connection, $query);
$rs = [];
for ($rownr = 0; odbc_fetch_row($result); $rownr++) {
for($colnr = 1; $colnr <= odbc_num_fields($result); $colnr++) {
$rs[$rownr][] = odbc_result($result, $colnr);
}
}
echo json_encode($rs);
odbc_close($connection);
?>
然而,它一直在说:
未定义索引:未定义索引:选项下拉列表
C:\Users\Me\voorraadbeheer\js\getVoorraad.php联机
4数组0{}空
如何从“选择”框中的选项中获取值或文本。所以我可以使用它吗?去掉onSubmit=getAlles并放置action=js/getVoorraad.php如果我错了,请纠正我,但这不是因为您没有通过getJSON调用传递任何数据吗
检查你的浏览器控制台,比如firebug,看看里面发生了什么。当您在onsubmit上调用refresh时,为什么它没有任何参数?您没有向PHP脚本传递任何参数。这就是为什么你会有这个问题。
window.onload = function()
{
$("#optionsDrop").change(function()
{
$.getJSON('js/getVoorraad.php',
{optionsDrop:$("#optionsDrop").val()},
function (data) {
refresh('#voorraadTable', data);
}
);
});
}