-2

我正在为网站进行基于复选框的过滤操作。这有多个复选框,用于过滤不同参数的记录列表。与此处所做的类似。现在我已经取得了一些成功,并且我已经过滤了记录基于第一组复选框。这是它的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

另外,我想知道我的方法是否正确。有更好的方法来实现吗?任何帮助表示赞赏。
谢谢

4

1 回答 1

2

尝试更改您的选择器。而不是这个:

$("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">

每个复选框组具有相同的名称。名称不能包含“[]”

于 2012-06-11T09:27:43.137 回答