blob: db0260c915e906ec07d92115729d11f6da399dd9 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
---
title: 'SyntaxError: unterminated string literal'
slug: Web/JavaScript/Reference/Erreurs/Unterminated_string_literal
tags:
- Erreurs
- JavaScript
- Reference
- SyntaxError
translation_of: Web/JavaScript/Reference/Errors/Unterminated_string_literal
---
<div>{{jsSidebar("Errors")}}</div>
<h2 id="Message">Message</h2>
<pre class="syntaxbox">SyntaxError: Unterminated string constant (Edge)
SyntaxError: unterminated string literal (Firefox)
</pre>
<h2 id="Type_d'erreur">Type d'erreur</h2>
<p>{{jsxref("SyntaxError")}}</p>
<h2 id="Quel_est_le_problème">Quel est le problème ?</h2>
<p>Une chaîne de caractères ({{jsxref("String")}}) n'est pas bien délimitée quelque part. Les littéraux de chaînes de caractères doivent être délimités par des simples quotes (') ou par des doubles quotes ("). <a href="/fr/docs/Web/JavaScript/Reference/Objets_globaux/String#Échappement_des_caractères">Les séquences d'échappement</a> permet de représenter dans ces chaînes de caractères. Pour réparer cette erreur :</p>
<ul>
<li>Vérifiez que la chaîne est bien délimitée au début et à la fin par des doubles quotes ou par des simples quotes,</li>
<li>Vérifiez que les caractères spéciaux de la chaîne ont bien été échappés,</li>
<li>Vérifiez que le littéral est bien découpé pour gérer plusieurs lignes (si c'est le cas).</li>
</ul>
<h2 id="Exemples">Exemples</h2>
<h3 id="Gérer_plusieurs_lignes">Gérer plusieurs lignes</h3>
<p>En JavaScript, on ne peut pas écrire une chaîne simple sur plusieurs lignes comme ceci :</p>
<pre class="brush: js example-bad">var longString = "This is a very long string which needs
to wrap across multiple lines because
otherwise my code is unreadable.";
// SyntaxError: unterminated string literal</pre>
<p>Pour écrire une chaîne sur plusieurs lignes, on pourra utiliser :</p>
<ul>
<li><a href="/fr/docs/Web/JavaScript/Reference/Opérateurs/Opérateurs_arithmétiques#Addition_()">L'opérateur +</a>,</li>
<li>Une barre oblique inversée ("\")</li>
<li><a href="/fr/docs/Web/JavaScript/Reference/Littéraux_gabarits">Des littéraux de gabarits</a></li>
</ul>
<p>Voici la première variante avec l'opérateur de concaténation :</p>
<pre class="brush: js example-good">var longString = "This is a very long string which needs " +
"to wrap across multiple lines because " +
"otherwise my code is unreadable.";
</pre>
<p>Sinon, on peut utiliser une barre oblique inversée à la fin de chaque ligne pour indiquer qu'elle continue sur la ligne suivante. Attention, il faudra qu'il n'y ait aucun espace ou autre caractère après la barre oblique (il peut bien entendu y avoir un saut de ligne) :</p>
<pre class="brush: js example-good">var longString = "This is a very long string which needs \
to wrap across multiple lines because \
otherwise my code is unreadable.";
</pre>
<p>On pourra également utiliser <a href="/fr/docs/Web/JavaScript/Reference/Littéraux_gabarits">les littéraux de gabarits</a> qui sont pris en charge par les environnement ECMAScript 2015 :</p>
<pre class="brush: js example-good">var longString = `This is a very long string which needs
to wrap across multiple lines because
otherwise my code is unreadable.`;</pre>
<h2 id="Voir_aussi">Voir aussi</h2>
<ul>
<li>{{jsxref("String")}}</li>
<li><a href="/fr/docs/Web/JavaScript/Reference/Littéraux_gabarits">Les littéraux de gabarits</a></li>
</ul>
|