0

这是我使用自动完成的代码,当我使用单个文件时可以正常工作,例如 aci.php 。(正常工作)

<?php
include_once('AFactory.class.php');
$db=new AFactory();
$db->getDBO();
if(isset($_POST['queryString'])) 
{
        $sql = "SELECT `name` FROM `liste_kala` WHERE `name` LIKE '%{$_POST['queryString']}%' LIMIT 0 , 30";
        $result=$db->setQuery($sql);
        $query=$db->setQuery($sql);
        $result=$db->loadAssoc($query); 
        // echo '<pre>';print_r($result);echo '</pre>';
        if($result) 
        {
            foreach ($result as $value) echo '<li onClick="fill(\''.$value['name'].'\');">'.$value['name'].'</li>';
        } 
}
?>

但是我将该代码粘贴到 action.php 文件中,我可以检查 post 方法的操作,但不能以这种方式工作:JQUERY 方法:

function lookup(inputString) {
    if(inputString.length == 0) {
        // Hide the suggestion box.
        $('#suggestions').hide();
    } else {
        $.post("aci.php", {queryString: ""+inputString+"" , postaction:'autocomplete' }, function(data){
            if(data.length >0) {
                $('#suggestions').show();
                $('#autoSuggestionsList').html(data);
            }
        });
    }
}

动作.PHP

<?php
include_once('AFactory.class.php');
$db=new AFactory();
$db->getDBO();
$action=$_POST['queryString'];
switch ($action)
{
    case 'autocomplete':
        if(isset($_POST['queryString'])) 
        {
                $sql = "SELECT `name` FROM `liste_kala` WHERE `name` LIKE '%{$_POST['queryString']}%' LIMIT 0 , 30";
                $result=$db->setQuery($sql);
                $query=$db->setQuery($sql);
                $result=$db->loadAssoc($query); 
                // echo '<pre>';print_r($result);echo '</pre>';
                if($result) 
                {
                    foreach ($result as $value) echo '<li onClick="fill(\''.$value['name'].'\');">'.$value['name'].'</li>';
                } 
        }
            break;

}
?>
4

1 回答 1

0
$action=$_POST['queryString'];

应该:

$action=$_POST['postaction'];
于 2012-10-08T17:06:21.293 回答