如何在提交时显示表单值(重新加载后)?

时间:2014-07-31 02:55:27

标签: php html database forms

我正在制作一个网络应用,目前正在用户可以输入其帐户详细信息的页面上工作。

该代码目前允许用户输入其帐户信息和小屋提交的值。当他们点击提交时,它会重新加载页面并将这些值保存到数据库中。但是,在确认表单重新提交后再次手动重新加载页面之前,它不会显示这些新值。

如何修复它以便信息自动更新?

我的表单如下:

<form action="" method="POST">
    <div class="row account-details">
        <div class="col-md-6">
                <div class="form-group">
                    <p>First Name</p>
                    <input type="text" name="firstname" class="form-control" style="border-radius:5px;border:1px solid #e9e9e9;" name="firstname" value="<?php echo $user['firstname'];?>">
                </div>
                <div class="form-group">
                    <p>Date of birth</p>
                    <input type="date" name="dob" class="form-control" style="border-radius:5px;border:1px solid #e9e9e9;" name="dob" value="<?php echo $user['dob'];?>">
                </div>
                <div class="form-group">
                    <p>Skype</p>
                    <input type="text" name="skype" class="form-control" style="border-radius:5px;border:1px solid #e9e9e9;" name="skype" value="<?php echo $user['skype'];?>">
                </div>
                <div class="form-group">
                    <p>Channel name</p>
                    <p class="channelname"><?php echo $user['username'];?></p>
                </div>
        </div>
        <div class="col-md-6">
                <div class="form-group">
                    <p>Last Name</p>
                    <input type="text" class="form-control" style="border-radius:5px;border:1px solid #e9e9e9;" name="lastname" value="<?php echo $user['lastname'];?>">
                </div>
                <div class="form-group">
                    <p>Country</p>
                    <select class="form-control" style="border-radius:5px;border:1px solid #e9e9e9;" name="country">
                     <?php foreach($countries as $c) {
                        ?>
                        <option value="<?php echo $c;?>" <?php if($user['country'] === $c) echo 'selected';?>><?php echo $c;?></option>
                        <?php }
                        ?>
                    </select>
                </div>
                <div class="form-group">
                    <p>Contact email</p>
                    <input type="email" class="form-control" style="border-radius:5px;border:1px solid #e9e9e9;" name="email" value="<?php echo $user['email'];?>">
                </div>
                <div class="form-group">
                    <p>Channel niche</p>
                    <select class="form-control" style="border-radius:5px;border:1px solid #e9e9e9;" name="niche">
                        <option>Gaming</option>
                        <option>-</option>
                        <option>-</option>
                    </select></div><input onSubmit="location.href='index.html'" style="border-radius:5px;margin-left:-90px;"  type="submit" class="btn btn-primary btn-lg" value="Submit"></form>

并且控制此表单的PHP看起来像:

        <?php if(isset($_POST) && !empty($_POST)) {
foreach($_POST as $k => $p) {
    $_POST[$k] = htmlspecialchars($p);
}

$db->where('id', $user['id']);
if($db->update('users', $_POST)) header("Location: account.php"); 
}
?>

2 个答案:

答案 0 :(得分:0)

我认为您的表单位于文件account.php中或包含在其中。由于表单POST到同一个URL,我假设您引用的PHP也在account.php或包含在其中。

如果是这种情况,您不需要发送位置标头,只需确保查询用户信息(填充表单的$user数组) 之后成功更新数据库。

根据要求作出一些澄清:

<?php
    // update db from $_POST
    // query db to populate $user array
?>
<form>
    <!-- inputs getting values from $user -->
</form>

答案 1 :(得分:0)

我假设您收到的表单数据类似于:

$user = getUserFromSomewhere($userID);
// $user is now an array with the user's data
//... handle post        
<!-- html comes now -->

如果您改为这样做:

//... handle post
$user = getUserFromSomewhere($userID);
// $user is now an array with the user's data
<!-- html comes now -->

在写入更改后,您的获取userdata的请求将会发生,因此可以正确显示。