我正在设置一个目录页面,该页面根据文本字段(有效(和/或复选框(不起作用(
来显示不同的锻炼。我不知道没有提交按钮是否可以,但我希望它可以搜索项目并让其搜索多个复选框
我尝试在互联网上寻求帮助,但找不到与我的项目相关的任何东西。
$sqlBrowse = "SELECT * FROM workoutLibrary
WHERE name LIKE :findInName
OR bodyPart LIKE :findInBodyPart
OR muscleGroup LIKE :findInMuscleGroup
OR equipment LIKE :findInEquipment
ORDER BY name";
$searchTerm = '';
$search = '%';
if (isset($_POST['search'])) {
$searchTerm = $_POST['search'];
$search = '%' . $searchTerm . '%';
$stmt = $conn->prepare($sqlBrowse);
$stmt->bindParam(":findInName", $search);
$stmt->bindParam(":findInBodyPart", $search);
$stmt->bindParam(":findInMuscleGroup", $search);
$stmt->bindParam(":findInEquipment", $search);
$stmt->execute();
$exercises = $stmt->fetchAll();
}
else if (isset($_POST['checklist'])) {
$searchTerm = $_POST['checklist'];
$search = '%' . $searchTerm . '%';
$stmt = $conn->prepare($sqlBrowse);
$stmt->bindParam(":findInEquipment", $search);
$stmt->execute();
$exercises = $stmt->fetchAll();
}
?>
html:
<form action="directory.php" method="post">
<input type="checkbox" name="checklist[]" class="check" value="Dumbell"> Dumbbell<br>
<input type="checkbox" name="checklist[]" class="check" value="kettlebell"> Kettlebell<br>
</form>
<div class="col-sm-10">
<h1 class="theTitle"> Workout Directory </h1>
<div class="d-flex flex-wrap">
<?php
foreach ($exercises as $exercise) {
?>
<div class="card" id="workoutCard">
<div class="card-header"> <?= $exercise->name ?> </div>
<div class="card-body">
<div class="thumbnail"> </div>
<div class="info">
<a id="subTitle">Body Parts:</a> <?= $exercise->bodyPart ?><BR>
<a id="subTitle">Muscle Group:</a> <?= $exercise->muscleGroup ?><BR>
<a id="subTitle">Equipment Used:</a> <?= $exercise->equipment ?>
</div>
</div>
</div>
<?php
}
?>
我的搜索栏非常完美,因此我没有为此显示HTML。我是初学者,所以我不确定自己出了问题,我不确定我是否可以在同一名称变量下执行两个PDO陈述。
任何帮助或提示都将不胜感激
更新:一个复选框现在将显示所有相关信息(没有清单[](,但对其中的两个不起作用(我相信我需要清单[]才能使两个工作起作用(所以我的新问题是,我该如何做:
$ search ='%'。$搜索期。'%';
显示的范围
我假设您希望您的表格在用户选中复选框时退回吗?如果是这样,请将单击事件添加到发布表格的复选框,例如
<input type="checkbox" name="checklist[]" class="check" onclick='document.forms[0].submit();' value="Dumbell"> Dumbbell<br>
<input type="checkbox" name="checklist[]" class="check" onclick='document.forms[0].submit();' value="kettlebell"> Kettlebell<br>
对于字符串转换错误的数组,这是由于表单字段中的清单属性。
当您使用清单[](这是一个数组(时,您将必须循环获得值:
else if (isset($_POST['checklist'])) {
$searchArray = $_POST['checklist'];
foreach ($searchArray as $searchTerm)
{
$search = '%' . $searchTerm . '%';
$stmt = $conn->prepare($sqlBrowse);
$stmt->bindParam(":findInEquipment", $search);
$stmt->execute();
$exercises = $stmt->fetchAll();
}
}