我希望一旦用户更新其个人资料上的信息,不要立即重新加载输入框。
这是一个例子:
User updates his age box:
User inputs 10
Displays 10
User inputs 20
Displays 10
Page Reload
Displays 20
我不知道为什么会这样。它需要一个FULL页面重新加载和页面刷新才能显示正确的信息:(
然而,一旦信息在数据库中更新,我打印信息 - 这是正确的。虽然感觉按钮重新加载整个页面,但这不起作用。以下是设置的变量:
function utf8_encode_string($value) {
if (empty($_POST[$value])) {
$str = "";
return $str;
}
else {
$str = utf8_encode(htmlspecialchars(trim($_POST[$value]), ENT_QUOTES));
return $str;
}
}
$urlquery = new user("username", $accounturl, $connection);
$locationinput = utf8_encode_string($urlquery->user_information("location"));
if (!$locationinput) {
$locationinput = utf8_encode(htmlspecialchars(trim($urlquery->user_information("location")), ENT_QUOTES));
}
<form method="post">
<input
type="text"
name="location"
id="locationinput"
value="<?php print utf8_decode($locationinput); ?>"
/>
</form>
class user {
public function __construct($row_name_1, $row_value_1, $connection) {
$this->row_name_1 = $row_name_1;
$this->row_value_1 = $row_value_1;
$this->connection = $connection;
}
public function user_update_information($updatecolumn, $updatecolumn_value) {
$query = "UPDATE users SET $updatecolumn = :updatecolumn WHERE $this->row_name_1 = :row_value_1";
$stmt = $this->connection->prepare($query);
$stmt->execute(array(':updatecolumn' => $updatecolumn_value,
':row_value_1' => $this->row_value_1));
}
public function user_information($information) {
$query = "SELECT * FROM users WHERE $this->row_name_1 = :row_value_1";
$params = array(':row_value_1' => $this->row_value_1);
try{
$stmt = $this->connection->prepare($query);
$result = $stmt->execute($params);
}
catch(PDOException $ex){
echo ("Failed to run query: " . $ex->getMessage());
}
$columns = $stmt->fetch();
return $columns[$information];
}
}
$location_for_database = "";
if (isset($locationinput))
{
$location_for_database = $locationinput;
}
else
{
$location_for_database = "";
}
$updateinfo = new user("id", $_SESSION["logged_in"], $connection);
$updateinfo->user_update_information(
"location",
($location_for_database)
);
如果您需要我的完整代码,可以在此处找到:http://pastebin.com/Cg2LQd7T
如果您希望我更好地解释我的问题,请告诉我。我已经工作了一个多月了,我无法解决它! :(
答案 0 :(得分:0)
我知道这只是一个:
但你可以使用
header("Refresh:0");
在页面上在完成保存数据库中的值后重新加载它。
P.S。 - 这是一个解决方法。