我正在制作一个网络应用,目前正在用户可以输入其帐户详细信息的页面上工作。
该代码目前允许用户输入其帐户信息和小屋提交的值。当他们点击提交时,它会重新加载页面并将这些值保存到数据库中。但是,在确认表单重新提交后再次手动重新加载页面之前,它不会显示这些新值。
如何修复它以便信息自动更新?
我的表单如下:
<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");
}
?>
答案 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的请求将会发生,因此可以正确显示。