从 MySql 填充选项选择菜单


Populating an options select menu from MySql

我正在尝试根据另一个菜单中的选择填充第二个选项选择菜单。问题是,我无法让jQuery执行它。这是我的代码

<head>
<script type="text/javascript">
$(document).ready(function()
{
$("#add_subject").change(function()
{
    var id=$(this).val();
    var dataString = 'id='+ id;
    $.ajax
    ({
        type: "POST",
        url: "inc.add.content.populate.php",
        data: dataString,
        cache: false,
        success: function(html)
        {
            $("#add_content").html(html);
        } 
    }); 
});
});
</script>
</head>
<div class="grid_10">
    <div class="box round first">
        <h2>Title</h2>
        <div class="block"> 
        <form method="post">
            <table class="form">
                 <tr>
                    <td>
                        <select id="add_subject" name="add_subject">
                            <option value="1">first option</option>                           
                        </select>
                        <select id="add_content" name="add_content">
                        </select>
                   </td>
                </tr>                
             </table>
        </form>           
        </div>
    </div>
</div>

和我的inc.add.content.populate.php文件

<?php
require_once(BASEDIR.'includes'.DIRECTORY_SEPARATOR.'inc.functions.php');
if($_POST['id'])
{
$id=$_POST['id'];
global $mysqli;
if($query = $mysqli->prepare("SELECT naslov,vsebine_id FROM table_vsebine WHERE predmet_id=?")){
    $query->bind_param('i',$id);
    if($query->execute()){
        $query->bind_result($naslov,$vsebine_id);
        $query->store_result();
        while($row = $query->fetch()){
        echo '<option value="'.$vsebine_id.'">'.$naslov.'</option>';
        }
    }
    }
}
?>

您正在尝试访问在应用程序中其他位置定义的常量

PHP 是一种无状态语言,这意味着每个连接都会得到不同的处理。

您可能希望定义BASEDIR,并且可能DIRECTOR_SEPARATOR正在使用它们的文件中。或者,如果在多个文件中使用它们,则可以将所有定义放入单个文件中,并在需要时包含它。

直接运行inc.add.content.populate.php文件,并且BASEDIR在您的index.php中定义,因此,在这种情况下,您的BASEDIR不会在此脚本中定义,因为在此 ajax 调用中未执行index.php

如果您将所有constant定义在一个单独的文件中,例如constants.php,并且只是在index.phpinc.add.content.populate.php中使用/包含它,那么它可以很容易地完成,例如

require_once('path/to/file/constants.php');
require_once(BASEDIR.'includes'.DIRECTORY_SEPARATOR.'inc.functions.php');
// ...