如何填充表单以编辑现有数据

but5z9lq  于 2021-06-17  发布在  Mysql
关注(0)|答案(1)|浏览(346)

这个问题在这里已经有答案了

php中单引号字符串和双引号字符串的区别是什么(12个答案)
两年前关门了。
更新代码以反映双引号与单引号。
我没有用mysql表中的date\u requested值填充,而是得到以下结果。

Date  <input type="text" id="datepicker" name="date_requested" value="$date_requested"> <br/><br/>

此行将在文本框中放置$date\u requested。
我也试过了

Date  <input type="text" id="datepicker" name="date_requested" value="<?php echo "$date_requested" ?>"/> <br/><br/>

这一行将php echo放在文本框中。
任何方向都是值得赞赏的。下面是代码的周围部分:

if($_SERVER['REQUEST_METHOD'] == "POST")
{
    mysql_connect("localhost", "root","") or die(mysql_error()); //Connect to server
    mysql_select_db("first_db") or die("Cannot connect to database"); //Connect to database
    $query = mysql_query("Select * from time_off_requests Where time_off_key='$time_off_key'"); // SQL Query
    $date_requested = $_POST["date_requested"];
    $time_off_begin = $_POST["time_off_begin"];
    $time_off_end = $_POST["time_off_end"];//date
    $use_pto = $_POST["use_pto"];
    $user = $_SESSION["user"];
    $time_off_key = $_SESSION["time_off_key"];
    mysql_query("UPDATE time_off_requests SET date_requested='$date_requested', time_off_begin='$time_off_begin', time_off_end='$time_off_end', use_pto='$use_pto' WHERE time_off_key='$time_off_key'") ;
    header("location: home.php");
}
if($tok_exists)
    {
    Print '
    <form action="edit.php" method="POST">
        Date  <input type="text" id="datepicker" name="date_requested" value="<?php echo "$date_requested" ?>"/> <br/><br/>
        All Day  <input type="checkbox" name="all_day[]" value="no" /> <br/>
        Start Time  <input type="time"  id="timepicker" name="time_off_begin" /> <br/>
        End Time  <input type="time" id="timepicker2" name="time_off_end" /> <br/> <br/>
        Use PTO <Select name="use_pto">
        <option value="">Select</option>
        <option value="Yes">Yes</option>
        <option value="No">No</option>
        </select> <br/><br/>
       <input type ="submit" value="Edit Request">  
    </form>
    ';
    }
    else
    {
        Print '<h2 align="center">There is no data to be edited.</h2>';
    }
?>
pkmbmrz7

pkmbmrz71#

你把单引号和双引号混用错了。将变量中的值设置到字符串中的一种更简单的方法是使用变量插值,这需要双引号( "" ).
所以

Print "<form action='edit.php' method='POST'>
    Date  <input type='text' id='datepicker' name='date_requested' value='$date_requested'/> <br/><br/>
</form>";

确实会输出

<form action='edit.php' method='POST'>
    Date  <input type='text' id='datepicker' name='date_requested' value='2018-12-12'/> <br/><br/>
</form>

这是因为php看到了这个变量 $date_requested 包含在双引号内的普通字符串中,并用其值替换它。变量周围的单引号被逐字解释并输出为包含html属性值的引号

相关问题