我正在为网站进行基于复选框的过滤器操作。这有多个复选框,用于过滤不同参数的记录列表。类似于这里所做的。现在我已经取得了一些成功,并且我根据第一组复选框过滤了记录。这是它的js函数。
.HTML:
<input type="checkbox" id="checkbox1" class="checkbox1" value="<?php echo $suburb['suburb_name']?>" name="Suburb_check[]" onClick="changeResults();" onChange="" >
Javascript:
function changeResults(){
var data = { 'venue[]' : []};
$("input[name=Suburb_check[]]:checked").each(function() { var chck1 = $(this).val();
data['venue[]'].push($(this).val());
dataString =data['venue[]'.toString()].toString();
});
$.ajax({
type : 'POST',
url : 'process.php',
data : "dataString="+dataString,
success : function(data){
$('#project_section').html(data);
}
});
}
这样做是过滤记录 + 加载第二组复选框。第一个设置复选框)=>对于区域,第二个是 =>对于位置我创建了一个数组来传递复选框值,然后将其转换为字符串(.toString)并传递给.php文件。
同样,我为第二组复选框创建了一个函数。.HTML
<input type="checkbox" onClick="changeLocality();" id="localityCheck" value="<?php echo $locality['locality_name'];?>" name="Locality_check[]">
.JS
function changeLocality(){
var dataLocality = {'locality[]' : []};
$("input[name=Locality_check[]]:checked").each(function() {
var chcklocal = $(this).val();
dataLocality['locality[]'].push($(this).val());
localityString =dataLocality['locality[]'.toString()].toString();
});
$.ajax({
type : 'POST',
url : 'processLocality.php',
data : "localityString="+localityString,
success : function(dataLocality){
$('#project_section').html(dataLocality); // replace the contents coming from php file
}
});
}
将值传递给 php 文件,但当我尝试使用 $_POST 获取它们时,字符串我相互混合,即区域值进入局部字符串,反之亦然(使用具有相同结果的数组尝试这样做,因此切换到字符串)。我无法解决这个问题。为什么会这样这是我发布值的 php 文件。进程局部性.php
<?php session_start();
include_once("includes/classes/db_connect.php");
include_once("pagination/paginator.class.php");
$pages = new Paginator();
$regions = "'".$_POST['dataString']."'";
echo $regions;
$arr = explode(",",$regions);
$getFormatedSuburb = implode("','",$arr);
$locality = "'".$_POST['localityString']."'";
echo $locality;
$arrLocal = explode(",",$locality);
$getFormatedLocality = implode("','",$arrLocal);
//Here I get the strings mixed with each other!!
?>
我在字符串中添加了一些表达式,以便以所需的格式将其传递给 SQL 查询的 IN 子句。现在,我得到的字符串包含来自区域和位置的值。我想要两者分开,因为它们是过滤记录的两个不同参数
Pune East,
Pune West, //1 and 2 are regions
Aundh,
Kalyaninagar //3 and 4 are localities
另外,我想知道我的方法是否正确。有什么更好的方法来实现这一点吗?任何帮助表示赞赏。
谢谢
尝试更改选择器。取而代之的是:
$("input[name=Suburb_check[]]:checked")
....
$("input[name=Locality_check[]]:checked")
这样做:
$("input[name=Suburb_check]:checked")
....
$("input[name=Locality_check]:checked")
此外,标记必须采用以下形式:
<input type="checkbox" name="Suburb_check">
每个复选框组的名称相同。名称不能包含"[]"