我尝试过检查其他答案,但我仍然感到困惑——尤其是在看到W3schools HTML5参考之后。

我认为HTML4.01应该“允许”单个标记仅为<img>和<br>。然后XHTML与<img/>和<br/>一起出现(有人说旧版浏览器的空间很大)。

现在我想知道在练习HTML5时应该如何格式化代码。

是<br>、<br/>还是<br/>?


当前回答

<br>是足够的,但根据WHATWG和W3C,XHTML<br/>是首选。

引用HTML 5.2 W3C建议第8.1.2.1节,2017年12月14日

开始标记必须具有以下格式:…在属性之后,或者如果没有属性,则在标记名称之后,可以有一个或多个空格字符。(某些属性后面需要加空格。请参见下面的§8.1.2.3属性。)然后,如果该元素是void元素之一,或者该元素是外来元素,则可能只有一个U+002F SOLIDUS字符(/)。此字符对void元素没有影响,但对外来元素,它将开始标记标记为自动关闭。

如果使用Dreamweaver CS6,则它将自动完成为<br/>。

要在W3C上验证HTML文件,请参阅:http://validator.w3.org/

其他回答

XML不允许打开标记,因此它比其他两个标记更糟糕。另外两个与第二个(<br/>)大致相当,以兼容较旧的浏览器。实际上,出于兼容性的考虑,/之前的空格是首选的,但我认为这只适用于具有属性的标记。所以我会说<br/>或<br/>,无论你的审美如何。

综上所述:这三个都是有效的,第一个(<br>)不那么“便携”。

编辑:现在我们都对规格着迷,我认为值得指出的是,根据dev.w3.org:

开始标记包括以下内容零件,完全按照以下顺序:“<”字符。元素的标记名。(可选)一个或多个属性,每个属性必须前面有一个或多个空格字符。(可选)一个或多个空格字符。(可选)“/”字符,仅当元素是空元素。“>”字符。

简单<br>就足够了。

其他形式是为了与XHTML兼容;以使编写与XHTML相同的代码成为可能,并使其作为HTML工作。一些生成HTML的系统可能基于XML生成器,因此无法仅输出一个简单的<br>标记;如果您正在使用这样的系统,可以使用<br/>,如果您不需要这样做,则不必使用。

然而,很少有人真正使用XHTML。您需要将内容作为application/xhtml+xml提供,以便将其解释为xhtml,而这在旧版本的IE中不起作用-这也意味着您犯的任何小错误都将阻止页面在支持xhtml的浏览器中显示。因此,web上看起来像XHTML的大部分内容实际上都是作为HTML提供和解释的。有关更多信息,请参阅将XHTML作为text/html提供。

<br/>是最合适的。在需要换行符而不是<br>的Reactjs中也可以使用此标记符号

XML要求所有标记都具有相应的结束标记。因此,对于没有内部内容的标记,有一种特殊的简短语法。

HTML5不是XML,因此不应该提出这样的要求。HTML 4.01也不是。

例如,在HTML5规范中,所有带有br标记的示例都使用<br>语法,而不是<br/>。

UPD实际上,<br/>在HTML5中是允许的。9.1.2.1, 7.

在HTML(最多HTML 4)中:使用<br>

在HTML 5中:<br>是首选,但<br/>和<br/>也是可以接受的

在XHTML中:<br/>是首选。也可以使用<br/>或<br></br>

笔记:

<br></br>在HTML 5中无效,它将被视为两个换行符。XHTML区分大小写,HTML不区分大小写。为了向后兼容,一些旧浏览器会将XHTML解析为HTML,并在<br/>时失败,但不会<br/>

参考:

http://www.w3schools.com/tags/tag_br.asphttp://en.wikipedia.org/wiki/XHTML