recherche
Maisoninterface Webtutoriel HTMLExplication détaillée de la balise code et de la balise pré en HTML

Préface

Il y a quelques jours, un collègue m'a posé une question sur les balises code et les balises pré. Eh bien, oui, ces deux balises se sont réunies. Alors je l'ai résumé. Cet article se concentrera sur la balise code et la balise pre, leurs définitions, leurs différences, leurs applications et comment utiliser ces deux types ensemble. Et lorsque ces deux balises sont imbriquées, comment les différents navigateurs interprètent cette imbrication.

1. Ordre d'imbrication

Les balises de code et les balises pré peuvent être imbriquées. Il convient de souligner qu'une version précédente de Firefox analysait l'imbrication des balises de code et des balises pré. entraîner une analyse incorrecte de la structure DOM par le navigateur. Il s'agit simplement d'un problème avec Firefox lui-même, et la dernière version peut déjà l'analyser correctement. Une analyse correcte fait référence à la capacité d'analyser correctement la structure DOM. Au total, l’ordre d’imbrication de ces deux balises peut désormais être arbitraire. Il n’y aura aucune erreur d’analyse de la structure DOM.

Lorsque nous écrivons le code suivant :


<pre class="brush:php;toolbar:false">
    <code>
        hello world    </code>

Le navigateur analyse correctement :

Analyse du code ci-dessus par le navigateur FF

2. Concernant les règles d'omission des balises pré et des balises code sous HTML5

La dernière spécification HTML5 définit des balises qui peuvent omettre la balise de fermeture. Par exemple, la balise

peut être écrite comme la balise

La balise pre et la balise code sont identiques à la balise p. La balise de fin peut être omise. Selon la norme HTML5, ce qui suit est également correct. Le résultat analysé est le même que le résultat analysé ci-dessus.


<pre class="brush:php;toolbar:false">
    <code>
          hello world

Firefox, IE9 et Chrome peuvent tous l'analyser correctement. Il est recommandé de lire la spécification d'omission de balise selon la norme HTML5 : c'est-à-dire que les deux façons d'écrire ci-dessus sont correctes.

Mais une chose à noter est que la spécification standard par défaut sous IE9 est l'image ci-dessous.


La norme par défaut sous Firefox et Chrome est l'image ci-dessous.

Dans l’ensemble, ils sont tous corrects. La structure du DOM est la même. Bien entendu, les espaces peuvent être considérés comme des nœuds. Je n’en parlerai pas en profondeur.

3. Définition de la balise code et de la balise pré

Balise code :

1. Définition de la balise code : Contenu textuel pouvant être lu par d’autres machines. Les rédacteurs de code logiciel sont habitués au format de code lors de l'écriture du code, cette balise est donc conçue pour les rédacteurs de code logiciel. Le texte de la balise code utilisera une police de type télétype à largeur fixe (Courier). .

2. L'application de balises de code ne doit être utilisée que pour représenter le code source d'un programme informatique ou tout autre contenu textuel pouvant être lu par des machines. Les fonctions de la balise incluent : changer le texte en une police à largeur fixe et une autre fonction consiste à impliquer que ce texte est du code source ; Ensuite, selon la deuxième fonction, le navigateur pourra à l'avenir ajouter des effets en fonction de sa propre situation réelle. Par exemple, le navigateur du programmeur peut rechercher des fragments de <code> et effectuer un formatage de texte supplémentaire, tel qu'une indentation spéciale des <a href="http://www.php.cn/code/6276.html" target="_blank"> boucles </a> et des instructions <a href="http://www.php.cn/code/10324.html" target="_blank"> conditionnelles </a>, etc.

3. Exemple de balise de code, nous pouvons regarder la différence de format entre le fragment de texte sans balise de code et le fragment de texte avec balise de code ci-dessous. Il convient de noter que cela ne démontre que la première fonction de la balise code. Quant à la fonction du programme source qui indique au navigateur ce code, elle doit être affichée sur un navigateur spécifique.

L'effet d'affichage du code suivant sur le navigateur est :

1 <code>
2     document.getELementById("id1");
3     document.getELementById("id2");
4     document.getELementById("id3");
5 </code>
6 <br>
7 document.getELementById("id4");

L'effet d'affichage est :

Voir la différence ? Ha ha. Regardons ensuite la balise pre.

pré-tag :

      1、pre标签的定义,

标签用来定义预格式化的文本,被包围在pre标签中的文本通常会保留空格和换行符, 而文本也会呈现出等宽字体。同样,pre标签的一个常见的应用便是用来保存计算机中的源代码文本。<p>      2、pre标签的功能,pre标签一个常见的应用便是用来保存计算机中的源代码的文本。但是,需要注意的是, 可以导致段落断开的标签(例如标题、</p><p> 和 </p><address> 标签)绝不能包含在 <pre class="brush:php;toolbar:false"> 所定义的块里。 pre标签允许的文本可以包括物理样式和基于内容的样式变化,还有链接、图像和水平分隔线。 当把其他标签(比如 <a> 标签)放到 <br><pre class="brush:php;toolbar:false"> 块中时,就像放在 HTML/XHTML 文档的其他部分中一样即可。<p>      3、pre标签的示例:下面的代码(html中的源代码)</p><p class="cnblogs_code"><br></p><pre class="brush:php;toolbar:false"> 1 <pre class="brush:php;toolbar:false"> 
 2     100db36a723c770d327fc0aef2ce13b1 
 3     93f0f5c25f18dab9d176bd4f6de5d30e 
 4     8f1fce76f77d4e6f6c69e7fe3c3a1bbb 
 5     2cacc6d41bbb37262a98f745aa00fbf0 
 6     9c3bca370b5104690d9ef395f2c5f8d1 
 7     6c04bd5ca3fcae76e30b72ad730ca86d 
 8     8019067d09615e43c7904885b5246f0a 
 9     xmlDoc=77893f97a0dd82388e0d49872b282c31loadXMLDoc5db79b134e9f6b82c0b36e0489ee08ed("books.xml");
 10     document.write("xmlDoc is loaded, ready for use");
 11     2cacc6d41bbb37262a98f745aa00fbf0
 12     36cc49f0c466276486e50c850b7e4956
 13     73a6ac4ed44ffec12cee46588e518a5e
 14 

      在浏览器中的显示效果为:

      左边的灰色的线是浏览器视窗的最左端呢,跟代码在文档中距离左边边距的距离是一样的呢。

四、code标签和pre标签之间的关系

      通过定义我们可以知道code标签和pre标签之间的关系,两者的共同点是应用上类似,都主要应用于浏览器显示计算机中的源代码。 但是两者之间还是有很大不同的,code标签的一个功能是暗示浏览器code标签所包围的文本是计算机源代码,浏览器可以做出自己的 样式处理,pre标签则没有这项功能,但是pre标签可以保留文本中的空格和换行符,保留文本中的空格和换行符是计算机源代码显示 所必须的样式。那么这个时候我们可以想象一下,code标签和pre标签可不可以一块使用呢?答案是可以的,code标签和pre标签是 可以嵌套使用的,但是必须注意两者的嵌套顺序。

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
HTML超文本标记语言--超在那里?(文档分析)HTML超文本标记语言--超在那里?(文档分析)Aug 02, 2022 pm 06:04 PM

本篇文章带大家了解一下HTML(超文本标记语言),介绍一下HTML的本质,HTML文档的结构、HTML文档的基本标签和图像标签、列表、表格标签、媒体元素、表单,希望对大家有所帮助!

html和css算编程语言吗html和css算编程语言吗Sep 21, 2022 pm 04:09 PM

不算。html是一种用来告知浏览器如何组织页面的标记语言,而CSS是一种用来表现HTML或XML等文件样式的样式设计语言;html和css不具备很强的逻辑性和流程控制功能,缺乏灵活性,且html和css不能按照人类的设计对一件工作进行重复的循环,直至得到让人类满意的答案。

web前端笔试题库之HTML篇web前端笔试题库之HTML篇Apr 21, 2022 am 11:56 AM

总结了一些web前端面试(笔试)题分享给大家,本篇文章就先给大家分享HTML部分的笔试题(附答案),大家可以自己做做,看看能答对几个!

总结HTML中a标签的使用方法及跳转方式总结HTML中a标签的使用方法及跳转方式Aug 05, 2022 am 09:18 AM

本文给大家总结介绍a标签使用方法和跳转方式,希望对大家有所帮助!

html中document是什么html中document是什么Jun 17, 2022 pm 04:18 PM

在html中,document是文档对象的意思,代表浏览器窗口的文档;document对象是window对象的子对象,所以可通过“window.document”属性对其进行访问,每个载入浏览器的HTML文档都会成为Document对象。

HTML5中画布标签是什么HTML5中画布标签是什么May 18, 2022 pm 04:55 PM

HTML5中画布标签是“<canvas>”。canvas标签用于图形的绘制,它只是一个矩形的图形容器,绘制图形必须通过脚本(通常是JavaScript)来完成;开发者可利用多种js方法来在canvas中绘制路径、盒、圆、字符以及添加图像等。

html5废弃了哪个列表标签html5废弃了哪个列表标签Jun 01, 2022 pm 06:32 PM

html5废弃了dir列表标签。dir标签被用来定义目录列表,一般和li标签配合使用,在dir标签对中通过li标签来设置列表项,语法“<dir><li>列表项值</li>...</dir>”。HTML5已经不支持dir,可使用ul标签取代。

Html5怎么取消td边框Html5怎么取消td边框May 18, 2022 pm 06:57 PM

3种取消方法:1、给td元素添加“border:none”无边框样式即可,语法“td{border:none}”。2、给td元素添加“border:0”样式,语法“td{border:0;}”,将td边框的宽度设置为0即可。3、给td元素添加“border:transparent”样式,语法“td{border:transparent;}”,将td边框的颜色设置为透明即可。

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

PhpStorm version Mac

PhpStorm version Mac

Le dernier (2018.2.1) outil de développement intégré PHP professionnel

Télécharger la version Mac de l'éditeur Atom

Télécharger la version Mac de l'éditeur Atom

L'éditeur open source le plus populaire

mPDF

mPDF

mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) ​​et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

Dreamweaver Mac

Dreamweaver Mac

Outils de développement Web visuel