PHP - HTML - 预览功能

4

今天我尝试制作一个PHP“HTML”编辑器,你可以编写你的“HTML”代码,预览它,然后将它发送到我的电子邮件。以下是代码:

<?php 
ini_set('display_errors', 1);
error_reporting(E_ALL);
if (isset($_POST['submit'])){
//     $to = file_get_contents('to.txt');
$to = "jonas.geiler@gmail.com";
$subject = "Form to email message";
$message = $_POST["message"];
$header  = 'MIME-Version: 1.0' . "\r\n";
$header .= 'Content-type: text/html; charset=UTF-8' . "\r\n";
$header .= 'From: Skayos Blog <blog.skayo@mail.com>' . "\r\n";
mail($to,$subject,$message,$header);
} else if (isset($_POST['preview'])){
 $output = $_POST["message"];
 echo $output;
}
?>

<!DOCTYPE html>
<head>
    <title>Form submission</title>
</head>

<body>
    <form action="" method="post">
        Message:<br>
        <textarea rows="5" name="message" cols="30">&lt;html&gt; &lt;body&gt; &lt;/body&gt; &lt;/html&gt;</textarea><br>
        <input type="submit" name="preview" value="Preview">
        <input type="submit" name="submit" value="Submit">
    </form>

</body>
</html> 

我的问题:如果我按预览,网页就会重新加载并显示预览,而代码会被删除。有没有简单的方法让代码留在文本框中呢?
谢谢, Skayo
1个回答

3

1) 当你的代码发布时,轻松解决方案是更改文本区域的值。

<?php    
    $msg = ""; 
    if (strlen($_POST['message'] > 0)
        $msg = $_POST['message'];
?>

Message:<br><textarea rows="5" name="message" 
value="<?php echo $msg; ?>" cols="30">&lt;html&gt; 
&lt;body&gt; &lt;/body&gt; &lt;/html&gt;</textarea><br>

2) 您可以使用AJAX动态加载内容,而无需重新加载页面。

<script>
function prewiev() {
    var xmlhttp = new XMLHttpRequest();
    xmlhttp.onreadystatechange = function() {
        if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
            document.getElementById("message").innerHTML = xmlhttp.responseText;
        }
    };
    xmlhttp.open("GET", "preview.php?str=" + document.getElementById("message").value, true);
    xmlhttp.send();
}


<form action="" method="post">
    Message:<br>
   <textarea id="message" rows="5" name="message" cols="30">
       &lt;html&gt;&lt;body&gt; &lt;/body&gt; 
       &lt;/html&gt;
   </textarea><br>
   <button name="preview" onClick="prewiev()">
   <input type="submit" name="submit" value="Submit">
</form>

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接