Table of contents
Un seul raccourci : <code>
Deux raccourcis sont prévus par SPIP pour afficher du code : <code>
ou <cadre>
.
Le premier raccourci, <code>
, sans doute le plus courant, s’utilise aussi bien pour un peu de code inline que pour un bloc de code. En effet, le code HTML qu’il génère s’adapte automatiquement, pour rester dans la ligne ou — dès lors qu’il contient plusieurs lignes de code — former un bloc qui va à la ligne.
Le second raccourci, <cadre>
, moins connu, génère un bloc de code formé de balises <textarea>
: c’est un usage complètement détourné du HTML mais qui, selon la documentation, était prévu pour permettre d’en copier-coller le contenu plus facilement.
Avec ce plugin qui facilite le copier-coller de n’importe quel bloc de code, le raccourci <cadre>
devient inutile. Il reste néanmoins fonctionnel, par souci de rétro-compatibilité, en adoptant le fonctionnement du raccourci <code>
.
Copier-coller facilité
Ce plugin facilite le copier-coller des blocs de code : en survolant le bloc de code, un bouton « Copier » s’affiche ; au clic son contenu est copié dans le presse-papier. Simple et efficace.

Cela fonctionne avec la petite librairie javascript clipboard.js.
Code généré correct : <pre><code>
Ce plugin rationalise l’affichage du code sous SPIP en générant du code HTML correct (conforme à la spécification HTML du W3C). Avec ce plugin, les blocs de code sont désormais correctement formés des balises HTML appropriées <pre>
et <code>
, comme suit :
<pre>
<code>
...
</code
>
</pre>
La balise HTML <pre>
a pour particularité de restituer le texte dans le code source de la même manière qu’il a été tapé : les espaces multiples, les tabulations et les sauts de ligne sont préservés. Pour en savoir plus, lire : À quoi sert la balise <pre>
?
Distinguer les différents langages
Pour que vos lecteurs et lectrices identifient plus facilement le type de code affiché, vous pouvez ajouter un attribut class sur le raccourci pour préciser le langage utilisé : spip, php, html, css, js, less, scss, etc. Par exemple <code class="spip">
affiche visuellement et discrètement dans un coin du bloc qu’il s’agit de code « spip » :

Personnaliser l’affichage
Ce plugin injecte une feuille de style dédiée pour assurer un rendu lisible et agréable de vos blocs de code.
- Pour visualiser le rendu, affichez la page de démo
../?page=demo/precode
dans votre site. - Ajoutez vos personnalisations d’affichage via CSS, dans votre propre feuille de style. Pour ce faire, consultez : Le CSS pour la balise pre.
Ce plugin est compatible avec le plugin Coloration Code : il surcharge ses traitements et génère un code HTML valide. Il n’est par contre pas compatible avec l’affichage des numéros de lignes, cette option de Coloration Code génère un balisage HTML irrécupérable.
Exemples
Ce plugin est visible en situation sur le site pour lequel il a été initialement développé, notamment dans les articles de la rubrique « Atelier SPIP » :

Il a été installé, associé à Coloration Code, sur les nouvelles versions des sites de la galaxie, où vous pouvez donc le voir fonctionner en situation : spip.net, programmer.spip.net et forum.spip.net

Évolutions
En l’état, ce plugin est un patch qui corrige le ticket 2504 : <pre> plutôt <div> pour afficher du code en bloc. Pour la suite, voir sa todo.
Discussions par date d’activité
4 discussions
Bonjour,
Est-ce qu’il serait possible de rajouter une option pour avoir les numéros de lignes affichés en plus ?
Merci
Me semblait que c’était disponible dans un autre plugin (avec la coloration syntaxique) qui vient surcharger celui-ci, non ?
Re bonjour,
En fait, c’est pre code qui est incompatible avec numérotation.
Sans ce plugin, la numérotation s’affiche.
Désolé pour le bruit (en plus, c’est dans la doc là-haut).
Ah oui, c’est vrai : de mémoire le code généré pour la numérotation s’appuie sur d’autres balises que
<pre>
et<code>
que ce plugin a pour but d’appliquer. Et pas certain qu’il soit possible de corriger la numérotation de façon à s’appuyer sur ces deux balises :(Reply to this message
Je découvre et salue ce greffon. C’est le genre de petits plus qui gagnent à être intégré dans le cœur de SPIP !
Par contre, je remarque un léger souci. Si par exemple on met <code class="spip">#BALISE</code> dans un texte ; celui-ci est récupéré par le plugin alors que c’est “inline” C’est fâcheux.
Je pense que le comportement normal ne devrait pas être changé quand on n’a pas plus d’une ligne de code...
Reply to this message
Oui !!! Facile a utiliser et très élégant :-)
J’ai juste un soucis avec le html, en utilisant
<code class="html">
cela m’affiche un cadre gris sans la possibilité de copier le code ni l’info html en haut a droite.Effectivement, il y a un problème avec
<code class="html">
, qui n’est pas du tout traité par le plugin.Je regarde ça.
Bon, alors c’est plutôt du côté de coloration_code qu’il y a un souci.
Tu l’utilises aussi ? essaie de le désactiver pour tester, et dis moi si tu confirmes.
Bonsoir, oui je confirme que sans Coloration code ca fonctionne
J’ai corrigé Coloration code pour qu’il utilise les traitements de Pre&code.
https://zone.spip.org/trac/spip-zone/changeset/109855
La version 0.9.17 devrait apparaitre rapidement dans SVP.
Excellent !! Merci :)
Reply to this message
Merci ! Très pratique sur les sites de la galaxie, avec un joli rendu.
Reply to this message
Ajouter un commentaire
Follow the comments:
|
