我根据从数据库中获得的一些数据生成表单。
这是我的构造函数:
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中,我需要保留输出结构和方法,所以我没有想法。
答案 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">';