diff options
Diffstat (limited to 'files/fr/web/api/text/splittext')
-rw-r--r-- | files/fr/web/api/text/splittext/index.html | 142 |
1 files changed, 142 insertions, 0 deletions
diff --git a/files/fr/web/api/text/splittext/index.html b/files/fr/web/api/text/splittext/index.html new file mode 100644 index 0000000000..034a953e46 --- /dev/null +++ b/files/fr/web/api/text/splittext/index.html @@ -0,0 +1,142 @@ +--- +title: Text.splitText() +slug: Web/API/Text/splitText +translation_of: Web/API/Text/splitText +--- +<div>{{apiref("DOM")}}</div> + +<p>La méthode <strong><code>Text.splitText()</code></strong> sépare le nœud {{domxref("Text")}} en deux nœuds au niveau de l’indice spécifié, et conserve les deux nœuds dans l’arbre en tant que voisins.</p> + +<p>Après la séparation, le nœud actuel contient tout le texte jusqu’à l’indice spécifié, et un nœud nouvellement créé du même type contient le texte restant. Le nœud nouvellement créé est retourné à l’appelant. Si le nœud original avait un parent, le nouveau nœud est inséré en tant que voisin suivant du nœud original. Si l’indice est égal à la longueur du nœud original, le nœud nouvellement créé ne contient pas de données.</p> + +<p>Des nœuds texte séparés peuvent être concaténés en utilisant la méthode {{domxref("Node.normalize()")}}.</p> + +<p>Une {{domxref("DOMException")}} avec la valeur <code>INDEX_SIZE_ERR</code> est levée si l’indice spécifié est négatif ou est supérieur au nombre d’unités 16-bit dans le texte du nœud ; une {{domxref("DOMException")}} avec la valeur <code>NO_MODIFICATION_ALLOWED_ERR</code> est levée si le nœud est en lecture seule.</p> + +<h2 id="Syntaxe">Syntaxe</h2> + +<pre class="syntaxbox"><em>noeudRemplacant</em> = <em>noeudTexte</em>.splitText(indice) +</pre> + +<h2 id="Exemple">Exemple</h2> + +<p>Dans cet exemple, le nœud texte d’un {{HTMLElement("p")}} est séparé en deux nœuds texte et un {{HTMLElement("span")}} est inséré entre les deux.</p> + +<pre class="brush:html"><body> + <p id="p">foobar</p> + + <script type="text/javascript"> + var p = document.getElementById('p'); + var noeudTexte = p.firstChild; + + // coupe entre foo et bar + var noeudRemplacant = noeudTexte.splitText(3); + + // crée un span avec ' contenu du span ' + var span = document.createElement('span'); + span.appendChild(document.createTextNode(' contenu du span ')); + + // ajoute le span avant 'bar' + p.insertBefore(span, noeudRemplacant); + + // le résultat est <p id="p">foo<span> contenu du span </span>bar</p> + </script> +</body> +</pre> + +<h2 id="Spécifications">Spécifications</h2> + +<table class="standard-table"> + <tbody> + <tr> + <th scope="col">Spécification</th> + <th scope="col">Statut</th> + <th scope="col">Commentaires</th> + </tr> + <tr> + <td>{{SpecName('DOM WHATWG', '#dom-text-splittext', 'Text.splitText')}}</td> + <td>{{Spec2('DOM WHATWG')}}</td> + <td>Pas de changement depuis {{SpecName('DOM3 Core')}}.</td> + </tr> + <tr> + <td>{{SpecName('DOM3 Core', 'core.html#ID-38853C1D', 'Text.splitText')}}</td> + <td>{{Spec2('DOM3 Core')}}</td> + <td>Pas de changement depuis {{SpecName('DOM2 Core')}}.</td> + </tr> + <tr> + <td>{{SpecName('DOM2 Core', 'core.html#ID-38853C1D', 'Text.splitText')}}</td> + <td>{{Spec2('DOM2 Core')}}</td> + <td>Pas de changement depuis {{SpecName('DOM1')}}.</td> + </tr> + <tr> + <td>{{SpecName('DOM1', 'level-one-core.html#ID-38853C1D', 'Text.splitText')}}</td> + <td>{{Spec2('DOM1')}}</td> + <td>Définition initiale.</td> + </tr> + </tbody> +</table> + +<h2 id="Compatibilité_des_navigateurs">Compatibilité des navigateurs</h2> + +<p>{{CompatibilityTable}}</p> + +<div id="compat-desktop"> +<table class="compat-table"> + <tbody> + <tr> + <th>Fonctionnalité</th> + <th>Chrome</th> + <th>Edge</th> + <th>Firefox (Gecko)</th> + <th>Internet Explorer</th> + <th>Opera</th> + <th>Safari</th> + </tr> + <tr> + <td>Support de base</td> + <td>1.0 [1]</td> + <td>{{CompatVersionUnknown}}</td> + <td>{{CompatGeckoDesktop("1.0")}}</td> + <td>{{CompatVersionUnknown}}</td> + <td>{{CompatVersionUnknown}} [1]</td> + <td>{{CompatVersionUnknown}} [2]</td> + </tr> + </tbody> +</table> +</div> + +<div id="compat-mobile"> +<table class="compat-table"> + <tbody> + <tr> + <th>Fonctionnalité</th> + <th>Android</th> + <th>Edge</th> + <th>Firefox Mobile (Gecko)</th> + <th>IE Mobile</th> + <th>Opera Mobile</th> + <th>Safari Mobile</th> + </tr> + <tr> + <td>Support de base</td> + <td>{{CompatVersionUnknown}} [1]</td> + <td>{{CompatVersionUnknown}}</td> + <td>{{CompatGeckoMobile("1.0")}}</td> + <td>{{CompatVersionUnknown}}</td> + <td>{{CompatVersionUnknown}} [1]</td> + <td>{{CompatVersionUnknown}} [2]</td> + </tr> + </tbody> +</table> +</div> + +<p>[1] Avant Chrome 30 et Opera 17, l’argument de <code>splitText()</code> n’était pas obligatoire, tel que requis par la spécification et implementé par IE et les navigateurs basés sur Gecko.</p> + +<p>[2] L’argument n’est pas obligatoire, bien que requis par la spec.</p> + +<h2 id="Voir_aussi">Voir aussi</h2> + +<ul> + <li>L’interface {{domxref("Text")}} à laquelle cette méthode appartient.</li> + <li>La méthode opposée : {{domxref("Node.normalize")}}.</li> +</ul> |