PHP生成POST表单

时间:2015-01-28 17:23:01

标签: javascript php jquery ajax forms

我根据从数据库中获得的一些数据生成表单。

这是我的构造函数:

php_core.php

<?php
    echo "<style>";
    echo ".spoll{ -webkit-box-sizing: border-box;";
    echo "-moz-box-sizing: border-box;";
    echo "box-sizing: border-box;";
    echo "padding: 10px;";
    echo "padding-top: 5px;";
    echo "}";
    echo "</style>";

    //DISPLAY FUNCTION

    function display($x){
        require("db_conx.php");
        $sql = "SELECT * FROM polls WHERE id='$x' LIMIT 1";
        $query = mysqli_query($db_conx, $sql);
        while ($row = mysqli_fetch_array($query, MYSQLI_ASSOC)){
            $poll_id = $row['id'];
            $topic = $row['topic'];
            $startdate = $row['startdate'];
            $stopdate = $row['stopdate'];
            $active = $row['active'];
            $type = $row['type'];
            $title = $row['title'];
            $pwidth = $row['pwidth'];
            $borcolor = $row['borcolor'];
            $borwidth = $row['borwidth'];
            $fcolor = $row['fcolor'];
            $bfcol = $row['bfcol'];
            $bg = $row['bg'];
            $borrad = $row['borrad'];
            $abars = $row['abars'];
            $bcol = $row['bcol'];
            $brad = $row['brad'];

        }

            //DISPLAY THE POLL
            $aquery = "SELECT * FROM answers WHERE parent='$poll_id'";
            $result = mysqli_query($db_conx, $aquery);
            echo '<div class="spoll" style="width: '.$pwidth.'px; border: '.$borwidth.'px solid '.$borcolor.'; border-radius: '.$borrad.'px; color: '.$fcolor.'; background-color: '.$bg.';">';
            echo '<p><b>'.$title.'</b></p>';
            echo '<p style="font-size: 13px;">'.$topic.'</p>';
            echo '<form method="post" action="'.$_SERVER['PHP_SELF'].'">';

            // SELECT ANSWERS
            if($type == 'single'){
                while ($usersRow = mysqli_fetch_array($result, MYSQLI_ASSOC)){
                    echo '<input type="radio" name="rad" value="'.$usersRow['id'].'"/>'.$usersRow['content'].'<br><br>';
                }
            } else {
                $i = 0;
                while ($usersRow = mysqli_fetch_array($result, MYSQLI_ASSOC)){
                    echo '<input type="checkbox" name="check[]" value="'.$usersRow['id'].'"/>'.$usersRow['content'].'<br><br>';
                    $i++;
                }
            }

            //echo '<button style="border-radius: '.$brad.'px; border: none; padding: 10px; width: 100%; margin: auto; background-color: '.$bcol.'; color:'.$bfcol.'" value="VOTE" onclick="vote('.$poll_id.');"><b>VOTE</b></button>';
            echo '<input type="submit" value="Vote" style="border-radius: '.$brad.'px; border: none; padding: 10px; width: 100%; margin: auto; background-color: '.$bcol.'; color:'.$bfcol.'">';
            echo '</form>';
            echo '</div>';
    }

    // END OF THE DISPLAY FUNCTION


?>

以下是我显示表单的方式:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<?php include("php_includes/php_core.php"); ?>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
</head>

<body>
<?php display('15'); ?>
<span id="status"></span>
<?php 
if(isset($_POST['submit'])){
echo "Posted!";
?>
</body>
</html>

我不知道为什么,但它不会提交价值!该函数正确输出表单,我通过查看页面源来检查它。我不知道为什么它不起作用,所以我需要你的帮助。我一次又一次地修改脚本,没有结果。

关于此脚本的其他(可选)问题: 您是否知道如何在没有任何其他HTML标签的情况下使用AJAX提交此表单并刷新函数输出而无需重新加载页面?我发现了一些方法,但我必须将函数包装在div中,我需要保留输出结构和方法,所以我没有想法。

2 个答案:

答案 0 :(得分:3)

您需要在提交按钮中添加name属性。

<input type="submit" value="Vote">

应该是

<input name="submit" type="submit" value="Vote">

您正在检查$_POST['submit']是否存在。

对于其他问题,我建议使用jQuery's Ajax函数。 See here

答案 1 :(得分:1)

它没有提交表单,因为您没有为按钮设置任何name

if(isset($_POST['submit'])){

}

submit不存在。

更改为:

echo '<input type="submit" name="submit">';