Попытка передать переменную из $ .post в php - PullRequest
2 голосов
/ 03 ноября 2011

У меня есть один большой файл (на данный момент), который должен:

  • взять переменную из виджета выбора в форме (jQuery)
  • отправить форму асинхронно (jQuery)
  • вернуть записи из базы данных, используя переменную, выбранную из формы (php)

Проблема в том, что переменная никогда не достигает php-кода.

Может кто-нибудь сказать мне, что я делаю не так, пожалуйста?

Мой код:

(все на одной странице)

    <script type="text/javascript">
        $(function() {
        $("select").change(function () {
              var str = "";
        $("select option:selected").each(function () {
     str += $(this).text() + " ";
        });   
        $.post("index.php", { zip: str}, function(data){
        $('result').text(str); }, "json" );

    });//end select
    });//end function
    </script>

    <?php include_once ('../cons.php'); ?>
    <?php 
    if (isset($_POST['zip'])){
    $value = $_POST['zip'];   
    }else{
    $value = "nada";
    }
    echo $value;

    //I only get "nada"
    ?>
</head>

<body>

<div id="body">
<form id="findzip"><!-- jQuery will handle the form -->
<select name="zip">
<option value="">Find your zip code</option>
    <?php //use php to pull the zip codes from the database
    $mysqli_zip = new mysqli(DB_HOST, DB_USER, DB_PASSWORD, DB_NAME);
    if (mysqli_connect_errno()) {
            printf("Connect failed: %s", mysqli_connect_error());
            exit();
    }
    $q_zip = "select distinct(zip) from mc m group by zip";
    $r_zip = $mysqli_zip->query($q_zip);
    if ((!$r_zip) || ($r_zip == NULL)) {
            echo "no results ";
    }
    while($row_zip = $r_zip->fetch_array(MYSQLI_BOTH)) {
        echo "<option value='". addslashes($row_zip['zip']) . "'>" . addslashes($row_zip['zip']) . "</option>;\n";
    }//end while

    ?>
</select>
</form>
<!-- here's where the results go -->
<result></result>
<br/>
</div>
</body>
</html>

Ответы [ 2 ]

2 голосов
/ 03 ноября 2011

Ваш скрипт в том виде, в котором он написан, отображает значение типа "12345". Но ваш $ .post ожидает, что это будет тип json. Когда я удалил тип json, он отлично сработал.

0 голосов
/ 03 ноября 2011

Попробуйте поставить на нем идентификатор, например:

<select name="zip" id="zip">

Тогда получим из него значение примерно так:

$("#zip").val();
...