我正在为网站进行基于复选框的过滤操作。这有多个复选框,用于过滤不同参数的记录列表。与此处所做的类似。现在我已经取得了一些成功,并且我已经过滤了记录基于第一组复选框。这是它的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);
}
});
}
这样做是过滤记录 + 加载第二组复选框.1st set check box)=> for Regions and 2nd is => for Localities 我创建了一个数组来传递复选框值,然后将其转换为字符串( .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 文件。processLocality.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
另外,我想知道我的方法是否正确。有更好的方法来实现吗?任何帮助表示赞赏。
谢谢