【问题标题】:How Do I set this PHP printed HTML form to stay within <p> tags?如何将此 PHP 打印的 HTML 表单设置为保留在 <p> 标记内?
【发布时间】:2014-07-19 19:35:24
【问题描述】:

所以我正在为我的网站构建一个相当简单的登录页面。 只有登录表单,一个由 PHP echo 命令打印的 HTML 表单,不想留在 HTML &lt;p&gt;&lt;/p&gt; 标记中。 代码如下:

<div ID="loginbox"><p> 
<?php
$db = mysqli_connect( $dbHost, $dbUser, $dbPass ) or die("Cannot connect to the server");?>

<?php      
if($_SESSION['authenticated']) { //// See if the user's logged in 
echo "You are logged in as $name "; //// If they are show message  
} else { //// if not logged show login form 
echo '<form action="login.php" method="post"><input type="hidden" name="ac" value="log"> '; 
echo 'Username: <input type="text" name="name" />';
echo '<br /> Password: <input type="password" name="password" />';
echo '<br /> <input type="submit" value="Login" />'; 
echo '</form><br />';
echo '<a href="registeruser.php">Don&#146;t have a login? click here to register</a>'; 
}
?>                
</p>
</div>

这里是相关的 CSS:

#loginbox {
border-radius: 15px;
color: black;
position:inherit;
width: 250px;
height: 100px;
margin-left: auto;
margin-right: auto;
margin-top: 55px;
}
#loginbox  > p {
border-radius: 15px;
background-color:white;
box-shadow:0 0 20px rgba(0, 0, 0, 0.4);
height:387px;
Width:500px;
top:60px;
left:50px;
font-family: palatino;
padding:50px 50px 37.5px 37.5px;}

#loginbox > form {    position: inherit;
z-index: 3;
top: 150px;
padding-left: 36px;
margin: 0 auto;}


#loginbox a:visited
{color:#010101;}

#loginbox a:hover
{color:#010101;}

#loginbox a:active
{color:#000000;}

And click here to see how it looks in-browser

【问题讨论】:

  • P标签开始了吗?我只看到结束 P 标记。
  • 另外,我会将我的连接到数据库行放在单独的文件connect_to_db.php 中,然后将include/require 该文件放在每个 php 脚本的最顶部需要连接数据库

标签: php html css forms tags


【解决方案1】:

基本问题:

主要错误是&lt;p&gt; 不允许包含非内联 内容。您可以完全删除&lt;p&gt;[&lt;/p&gt;][1], 或者,将它们移到 &lt;form&gt; 内。

至于“为什么”,这是因为它在架构中是这样定义的 定义什么是有效的 XHTML 什么是无效的。如果你看这个 XHTML definition 的部分你会看到 &lt;p&gt; 只是 允许包含文本或“内联”(不是“块”)标签。然而一个 &lt;form&gt; 算作“阻止”内容而不是“内联”内容。

换句话说,表单可以包含段落,但段落不能 包含表格。

【讨论】:

  • 感谢您的帮助!我将用 div 标签替换 P 标签。
【解决方案2】:

我在浏览器中看到&lt;p&gt; 标记在&lt;form&gt; 标记之前打开和关闭,另一个&lt;p&gt; 标记在&lt;/form&gt; 标记之后打开和关闭。

&lt;p&gt; 标签仅用于格式化文本内容。使用&lt;div&gt; 标签而不是&lt;p&gt; 标签。

【讨论】:

  • 您在寻找源代码还是控制台格式的代码?因为控制台 html 已正确关闭和打开,即使它缺少某些标记部分。
  • 控制台格式的代码。是的,我的意思是代码的浏览器呈现。
【解决方案3】:

&lt;form&gt; 元素不允许在 &lt;p&gt; 元素中。您的浏览器看到此无效代码并决定纠正此问题的最佳方法是在 &lt;form&gt; 开始之前假装&lt;p&gt; 已结束。

如果您将&lt;p&gt; 替换为&lt;div&gt;,您的代码将执行您想要的操作。

【讨论】:

  • 将管理特定 &lt;p&gt;&lt;/p&gt; 标记的 CSS 换成它自己的 CSS 类,然后将 p 标记换成具有所述 CSS 的 ID 的 Div 标记。像魅力一样工作!
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-10-22
  • 2011-06-12
  • 1970-01-01
  • 2019-04-07
  • 1970-01-01
相关资源
最近更新 更多