diff options
author | SphinxKnight <SphinxKnight@users.noreply.github.com> | 2021-12-04 17:38:30 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-12-04 17:38:30 +0100 |
commit | 530dfca848063fd49ef4b73c169bfb9485e12e85 (patch) | |
tree | a6f5c70c4c7064ec96bafc71c1c6ee648e734688 /files/fr/web | |
parent | e11085ffae53e32944433641373d2e1472b13e1b (diff) | |
download | translated-content-530dfca848063fd49ef4b73c169bfb9485e12e85.tar.gz translated-content-530dfca848063fd49ef4b73c169bfb9485e12e85.tar.bz2 translated-content-530dfca848063fd49ef4b73c169bfb9485e12e85.zip |
Redo fix for #2890 in md (#2957)
Diffstat (limited to 'files/fr/web')
-rw-r--r-- | files/fr/web/guide/html/editable_content/index.md | 232 |
1 files changed, 205 insertions, 27 deletions
diff --git a/files/fr/web/guide/html/editable_content/index.md b/files/fr/web/guide/html/editable_content/index.md index 1e1f4fdb29..71598b7197 100644 --- a/files/fr/web/guide/html/editable_content/index.md +++ b/files/fr/web/guide/html/editable_content/index.md @@ -1,46 +1,224 @@ --- -title: Contenu éditable +title: Rendre le contenu éditable slug: Web/Guide/HTML/Editable_content translation_of: Web/Guide/HTML/Editable_content original_slug: Web/HTML/Contenu_editable --- -## Introduction +> **Attention :** Comme indiqué par l'avertissement de la spécification pour [`execCommand()`](https://w3c.github.io/editing/docs/execCommand/), les fonctionnalités correspondantes ne sont pas implémentées complètement ou de façon cohérente entre les différents agents utilisateurs. De plus, cette fonction est indiquée comme dépréciée sur la page de référence pour [`Document.execCommand()`](/fr/docs/Web/API/Document/execCommand). Aussi, ce qui suit sur cette page ne devrait pas être utilisé pour du code en production. -Chaque élément du HTML5 peut être éditable. Cette fonctionnalité a été introduite longtemps auparavant mais a maintenant été standarisée avec [WHATWG](http://www.whatwg.org/) ([voir la spécification HTML actuelle](http://www.whatwg.org/specs/web-apps/current-work/multipage/editing.html#contenteditable)). Avec des gestionnaires d'événements JavaScript, vous pouvez transformer votre page Web en un éditeur de texte, complet et rapide. +En HTML, tout élément peut être éditable. En utilisant des gestionnaires d'évènements JavaScript, on peut transformer une page web en un éditeur de texte riche. Cet article fournit des informations à propos de cette fonctionnalité. -## Compatibilité +> **Note :** À partir de Firefox 63 Beta/Dev, certaines des fonctionnalités d'édition de texte riche ont été désactivées par défaut pour des raisons de compatibilité entre navigateurs. Les fonctionnalités retirées concernent des objets pour redimensionner des images ([`<img>`](/fr/docs/Web/HTML/Element/Img)), des tableaux ([`<table>`](/fr/docs/Web/HTML/Element/table)), et des éléments positionnés de façon absolue ; l'édition de tableaux en ligne pour ajouter ou retirer des lignes ou des colonnes ; la poignée qui permet de déplacer des éléments positionnés de façon absolue. Voir le [bug 1449564](https://bugzilla.mozilla.org/show_bug.cgi?id=1449564) pour plus de détails. -Le contenu éditable est entièrement compatible avec les navigateurs actuels : +## Le fonctionnement -- Firefox 3.5+ -- Chrome 6.0+ -- Internet Explorer 6.0+ -- Safari 3.2+ -- Opera 8+ -- iOS Safari 5.0+ -- Android Browser 3.0+ +Pour rendre un élément HTML éditable, il suffira de lui ajouter l'attribut [`contenteditable`](/fr/docs/Web/HTML/Global_attributes#attr-contenteditable). Cela fonctionne pour la quasi-totalité des éléments. -Ce n'est pas encore supporté par Opera Mini et Opera Mobile. +Voici un exemple simple qui crée un élément [`<div>`](/fr/docs/Web/HTML/Element/div) dont le contenu peut être édité par l'utilisateur. -## Comment ça marche ? +```html +<div contenteditable="true"> + Vous pouvez éditer ce texte lorsque vous consultez la page. +</div> +``` -Fixez l'attribut `contenteditable` à `true` dans votre élément HTML. Ça peut être fait dans quasiment tous les éléments HTML. +Et voici le résultat obtenu avec ce fragment HTML : -## Exemples +{{EmbedLiveSample('Le fonctionnement')}} -Un exemple simple : +## Exécuter des commandes - <!DOCTYPE html> - <html> - <body> - <div contenteditable="true"> - Ce texte peut être édité par l'utilisateur. - </div> - </body> - </html> +Lorsqu'un élément HTML a un attribut `contenteditable` qui vaut `true`, la méthode [`document.execCommand()`](/fr/docs/Web/API/Document/execCommand) devient disponible. Cela permet d'exécuter des [commandes](/fr/docs/Web/API/Document/execCommand#commandes) our manipuler les contenus de la région éditable. Certaines commandes affectent la sélection du document en mettant par exemple en forme le texte (gras, italique, etc.) tandis que d'autres insèrent de nouveaux éléments (par exemple un nouveau lien) ou portent sur tout une ligne (par exemple pour l'indenter). Lorsqu'on utilise `contentEditable`, appeler `execCommand()` aura un impact sur l'ensemble de l'élément éditable courant qui est actif. -Vous pouvez observer un exemple concret intégrant JavaScript utilisant LocalStorage [ici](http://html5demos.com/contenteditable). Le code source est disponible [ici](http://html5demos.com/contenteditable#view-source). +## Différences de génération de balisage + +L'utilisation de `contenteditable` parmi les différents navigateurs fut longtemps compliqué en raison des différences sur le balisage généré. Ainsi, même une action simple (presser Entrée pour créer une nouvelle ligne de texte au sein d'un élément éditable) pouvait être gérée différemment selon les navigateurs (Firefox insérait un élément [`<br>`](/fr/docs/Web/HTML/Element/br), IE/Opera ajoutaient un élément [`<p>`](fr/docs/Web/HTML/Element/p), Chrome/Safari ajoutaient un élément [`<div>`](/fr/docs/Web/HTML/Element/div). + +Cela s'est heureusement amélioré avec le temps et une meilleure cohérence s'est mise en place. Avec [Firefox 60](/fr/docs/Mozilla/Firefox/Releases/60), Firefox placera les différentes lignes dans des éléments [`<div>`](/fr/docs/Web/HTML/Element/div), ayant ainsi le même comportement que Chrome, Opera, Edge, et Safari. + +Vous pouvez essayer ceci dans l'exemple ci-avant. + +> **Note :** Internet Explorer, qui n'est plus maintenu, utilisait des éléments [`<p>`](/fr/docs/Web/HTML/Element/p) plutôt que des [`<div>`]. + +Si vous souhaitez utiliser un séparateur de paragraphe différent, l'ensemble des navigateurs prennent en charge [`document.execCommand`](/fr/docs/Web/API/Document/execCommand), qui fournit une commande `defaultParagraphSeparator` pour changer ce séparateur. Ainsi, pour utiliser des paragraphes ([`<p>`](/fr/docs/Web/HTML/Element/p)), on pourra exécuter : + +```js +document.execCommand("defaultParagraphSeparator", false, "p"); +``` + +De plus, Firefox prend en charge un argument *non-standard*, `br`, pour `defaultParagraphSeparator` depuis Firefox 55. Celui-ci peut s'avérer utile au cas où votre application web se base sur le comportement utilisé par les anciennes versions de Firefox. Pour retrouver l'ancien comportement de Firefox, vous pourrez utiliser cette ligne (uniquement dans Firefox) : + +```js +document.execCommand("defaultParagraphSeparator", false, "br"); +``` + +## Sécurité + +Pour des raisons de sécurité, par défaut, Firefox ne permet pas au code JavaScript d'utiliser les fonctionnalités du presse-papier (copier, coller, etc.). Cela peut être débrayé dans les préférences `about:config` : + + user_pref("capability.policy.policynames", "allowclipboard"); + user_pref("capability.policy.allowclipboard.sites", "https://www.mozilla.org"); + user_pref("capability.policy.allowclipboard.Clipboard.cutcopy", "allAccess"); + user_pref("capability.policy.allowclipboard.Clipboard.paste", "allAccess"); + +## Un exemple d'éditeur de texte + +```html +<!doctype html> +<html> +<head> +<title>Rich Text Editor</title> +<script type="text/javascript"> +var oDoc, sDefTxt; + +function initDoc() { + oDoc = document.getElementById("textBox"); + sDefTxt = oDoc.innerHTML; + if (document.compForm.switchMode.checked) { setDocMode(true); } +} + +function formatDoc(sCmd, sValue) { + if (validateMode()) { document.execCommand(sCmd, false, sValue); oDoc.focus(); } +} + +function validateMode() { + if (!document.compForm.switchMode.checked) { return true ; } + alert("Uncheck \"Show HTML\"."); + oDoc.focus(); + return false; +} + +function setDocMode(bToSource) { + var oContent; + if (bToSource) { + oContent = document.createTextNode(oDoc.innerHTML); + oDoc.innerHTML = ""; + var oPre = document.createElement("pre"); + oDoc.contentEditable = false; + oPre.id = "sourceText"; + oPre.contentEditable = true; + oPre.appendChild(oContent); + oDoc.appendChild(oPre); + document.execCommand("defaultParagraphSeparator", false, "div"); + } else { + if (document.all) { + oDoc.innerHTML = oDoc.innerText; + } else { + oContent = document.createRange(); + oContent.selectNodeContents(oDoc.firstChild); + oDoc.innerHTML = oContent.toString(); + } + oDoc.contentEditable = true; + } + oDoc.focus(); +} + +function printDoc() { + if (!validateMode()) { return; } + var oPrntWin = window.open("","_blank","width=450,height=470,left=400,top=100,menubar=yes,toolbar=no,location=no,scrollbars=yes"); + oPrntWin.document.open(); + oPrntWin.document.write("<!doctype html><html><head><title>Print<\/title><\/head><body onload=\"print();\">" + oDoc.innerHTML + "<\/body><\/html>"); + oPrntWin.document.close(); +} +</script> +<style type="text/css"> +.intLink { cursor: pointer; } +img.intLink { border: 0; } +#toolBar1 select { font-size:10px; } +#textBox { + width: 540px; + height: 200px; + border: 1px #000000 solid; + padding: 12px; + overflow: scroll; +} +#textBox #sourceText { + padding: 0; + margin: 0; + min-width: 498px; + min-height: 200px; +} +#editMode label { cursor: pointer; } +</style> +</head> +<body onload="initDoc();"> +<form name="compForm" method="post" action="sample.php" onsubmit="if(validateMode()){this.myDoc.value=oDoc.innerHTML;return true;}return false;"> +<input type="hidden" name="myDoc"> +<div id="toolBar1"> +<select onchange="formatDoc('formatblock',this[this.selectedIndex].value);this.selectedIndex=0;"> +<option selected>- formatting -</option> +<option value="h1">Title 1 <h1></option> +<option value="h2">Title 2 <h2></option> +<option value="h3">Title 3 <h3></option> +<option value="h4">Title 4 <h4></option> +<option value="h5">Title 5 <h5></option> +<option value="h6">Subtitle <h6></option> +<option value="p">Paragraph <p></option> +<option value="pre">Preformatted <pre></option> +</select> +<select onchange="formatDoc('fontname',this[this.selectedIndex].value);this.selectedIndex=0;"> +<option class="heading" selected>- font -</option> +<option>Arial</option> +<option>Arial Black</option> +<option>Courier New</option> +<option>Times New Roman</option> +</select> +<select onchange="formatDoc('fontsize',this[this.selectedIndex].value);this.selectedIndex=0;"> +<option class="heading" selected>- size -</option> +<option value="1">Very small</option> +<option value="2">A bit small</option> +<option value="3">Normal</option> +<option value="4">Medium-large</option> +<option value="5">Big</option> +<option value="6">Very big</option> +<option value="7">Maximum</option> +</select> +<select onchange="formatDoc('forecolor',this[this.selectedIndex].value);this.selectedIndex=0;"> +<option class="heading" selected>- color -</option> +<option value="red">Red</option> +<option value="blue">Blue</option> +<option value="green">Green</option> +<option value="black">Black</option> +</select> +<select onchange="formatDoc('backcolor',this[this.selectedIndex].value);this.selectedIndex=0;"> +<option class="heading" selected>- background -</option> +<option value="red">Red</option> +<option value="green">Green</option> +<option value="black">Black</option> +</select> +</div> +<div id="toolBar2"> +<img class="intLink" title="Clean" onclick="if(validateMode()&&confirm('Are you sure?')){oDoc.innerHTML=sDefTxt};" src="" /> +<img class="intLink" title="Print" onclick="printDoc();" src=""> +<img class="intLink" title="Undo" onclick="formatDoc('undo');" src="" /> +<img class="intLink" title="Redo" onclick="formatDoc('redo');" src="" /> +<img class="intLink" title="Remove formatting" onclick="formatDoc('removeFormat')" src=""> +<img class="intLink" title="Bold" onclick="formatDoc('bold');" src="" /> +<img class="intLink" title="Italic" onclick="formatDoc('italic');" src="" /> +<img class="intLink" title="Underline" onclick="formatDoc('underline');" src="" /> +<img class="intLink" title="Left align" onclick="formatDoc('justifyleft');" src="" /> +<img class="intLink" title="Center align" onclick="formatDoc('justifycenter');" src="" /> +<img class="intLink" title="Right align" onclick="formatDoc('justifyright');" src="" /> +<img class="intLink" title="Numbered list" onclick="formatDoc('insertorderedlist');" src="" /> +<img class="intLink" title="Dotted list" onclick="formatDoc('insertunorderedlist');" src="" /> +<img class="intLink" title="Quote" onclick="formatDoc('formatblock','blockquote');" src="" /> +<img class="intLink" title="Delete indentation" onclick="formatDoc('outdent');" src="" /> +<img class="intLink" title="Add indentation" onclick="formatDoc('indent');" src="" /> +<img class="intLink" title="Hyperlink" onclick="var sLnk=prompt('Write the URL here','http:\/\/');if(sLnk&&sLnk!=''&&sLnk!='http://'){formatDoc('createlink',sLnk)}" src="" /> +<img class="intLink" title="Cut" onclick="formatDoc('cut');" src="" /> +<img class="intLink" title="Copy" onclick="formatDoc('copy');" src="" /> +<img class="intLink" title="Paste" onclick="formatDoc('paste');" src="" /> +</div> +<div id="textBox" contenteditable="true"><p>Lorem ipsum</p></div> +<p id="editMode"><input type="checkbox" name="switchMode" id="switchBox" onchange="setDocMode(this.checked);" /> <label for="switchBox">Show HTML</label></p> +<p><input type="submit" value="Send" /></p> +</form> +</body> +</html> +``` ## Voir aussi -[Comment interagir avec le contenu ](/fr/docs/Midas "en/Midas")(style proche de l'ancienne API Internet Explorer) ou encore [ici](/fr/docs/Rich-Text_Editing_in_Mozilla "en/rich-text editing in mozilla").
\ No newline at end of file +- [`HTMLElement.contentEditable`](/fr/docs/Web/API/HTMLElement/contentEditable) +- L'attribut universel [`contenteditable`](/fr/docs/Web/HTML/Global_attributes#contenteditable) +- [`caret-color`](/fr/docs/Web/CSS/caret-color), qui permet de définir la couleur pour le curseur d'insertion de texte |