1

所以我有一个用户用一些单选按钮填写的表格。单选按钮的值被传递给 MySQL。我现在想从数据库中提取这些值,将它们显示在不同页面的表格中,并使用 span 标签对它们应用不同的样式。

这是表单中的代码:

<input class="radio_style" type="radio" name="job_type" value="fulltime"/>Full-time<br/>
<input class="radio_style" type="radio" name="job_type" value="parttime"/>Part-time<br />

这是我要显示它的页面的代码:

<div class='job_type_div'>
    <?php if($job_type=='fulltime') {?>
        <span class='job_type_style'>
            <?php echo $row['job_type']; ?>
        </span>
   <?php if($job_type=='parttime') {?>
        <span class='job_type_style2'>
            <?php echo $row['job_type']; ?>
        </span>
            <?php } ?>
    <?php } ?>
</div>

因此,理想情况下,“全职”值将具有一种风格,而“兼职”值将具有另一种风格。但是当我尝试运行这段代码时,什么也没有发生。我肯定正确连接到数据库。并且行名称正确标记为“job_type”。关于我可能出错的地方有什么想法吗?任何帮助将不胜感激 :)

4

5 回答 5

2

首先,您的表单应该是这样的:

<form action="page_you_want_to_display.php" method="POST">

    <label for="type">Job Type:</label>

    <label for="fulltime">
        <input class="radio_style" id="fulltime" name="job_type" type="radio" value="fulltime">
        Fulltime
    </label>

    <label for="parttime">
        <input class="radio_style" id="parttime" name="job_type" type="radio" value="parttime">
        Part Time
    </label>

    <input name="submitted" type="submit" value="Submit">

</form>

您要显示的页面应如下所示:

if(isset($_POST["submitted"])){

    $job_type = $_POST['job_type'];

    echo '<div class="job_type_div">';

        if($job_type=='fulltime'){

            $res = mysql_query("SELECT * FROM jobs WHERE job_type='fulltime'");

            while ($row = mysql_fetch_assoc($res)) {

                echo '<div class="fulltime">';

                    echo $row['job_title'].' - '.$row['job_type'];

                echo '</div>';

                echo '<br>';

            }

        } elseif ($job_type=='parttime'){

            $res = mysql_query("SELECT * FROM jobs WHERE  job_type='parttime'");

            while ($row = mysql_fetch_assoc($res)) {

                echo '<div class="parttime">';

                    echo $row['job_title'].' - '.$row['job_type'];

                echo '</div>';

                echo '<br>';

            }               

        }

echo '</div>';

}

和 CSS:

.fulltime {
    margin:0px;
    padding:5px;
    width:300px;
    background:#9C0;
    color:#fff;
}   
.parttime {
    margin:0px;
    padding:5px;
    width:300px;
    background:#069;
    color:#fff;
}

测试:

在此处输入图像描述

希望这可以帮助

于 2012-05-03T23:30:51.067 回答
0

我不相信条件会按照您实施的方式起作用,请尝试这样做:

<?php
echo "<div class='job_type_div'>";
if($job_type=='fulltime') {
        echo "<span class='job_type_style'>"

//ETC...

于 2012-05-03T22:59:47.140 回答
0

表单.php

如果您最初在表单中设置了一个“选定”,则不需要检查其设置,简单的设置数据库,如下所示:

...
mysql_query("UPDATE X SET (job_type='{$_GET['job_type']}') WHERE Y");
...

显示.php

由于您可能会制作样式表,请使用您放入数据库中的 job_type 标签引用选择器

while($row = mysql_fetch_assoc($resultsource))
   echo "<div class='job_type_div'> <span class='{$row['job_type']}_style'>{$row['job_type']}</span>";
于 2012-05-03T23:04:25.020 回答
0

从数据库中获取数组时,您需要使用 MYSQL_BOTH 来按名称获取列。

   mysql_fetch_array($res, MYSQL_BOTH)

所以你应该有这样的东西:

$job_type_query = "SELECT * FROM `job`; ";

$res = mysql_query($job_type_query) or die(mysql_error());
while ($row = mysql_fetch_array($res, MYSQL_BOTH))
{
   echo $row['job_type'];
}
于 2012-05-03T23:04:36.177 回答
0

可能是您的 php.ini 中的问题。有什么逻辑吗?

$job_type=null;
if($job_type=='fulltime'){
   ...
   if($job_type=='parttime'){
      ...
   }
}

你设置了 $job_type 变量吗?可能你需要这样的东西:

<div class='job_type_div'>
    <?php if($row['job_type']=='fulltime') {?>
        <span class='job_type_style'>
            <?php echo $row['job_type']; ?>
        </span>
   <?php } elseif($row['job_type']=='parttime') {?>
        <span class='job_type_style2'>
            <?php echo $row['job_type']; ?>
        </span>
    <?php } ?>
</div>
于 2012-05-04T00:58:25.420 回答