blob: 73badf1974ffabf1e543c7a6c376101365968ce2 (
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
 | ---
title: SyntaxError
slug: Web/JavaScript/Reference/Global_Objects/SyntaxError
tags:
  - Class
  - JavaScript
  - Object
  - Reference
  - SyntaxError
translation_of: Web/JavaScript/Reference/Global_Objects/SyntaxError
browser-compat: javascript.builtins.SyntaxError
---
<div>{{JSRef}}</div>
<p>
  <code><strong>SyntaxError</strong></code
  > 객체는 문법적으로 유효하지 않은 코드를 해석하려고 시도할 때 발생하는 오류를
  의미합니다. Javascript 엔진이 코드를 구문 분석할 때 언어의 구문에 맞지 않는
  토큰이나 토큰 순서를 만나면 이 오류를 던집니다.
</p>
<h2 id="생성자">생성자</h2>
<dl>
  <dt>{{jsxref("Global_Objects/SyntaxError/SyntaxError", "SyntaxError()")}}</dt>
  <dd>새로운 <code>SyntaxError</code> 객체를 만듭니다.</dd>
</dl>
<h2 id="인스턴스_속성">인스턴스 속성</h2>
<dl>
  <dt>
    {{jsxref("Error.prototype.message", "SyntaxError.prototype.message")}}
  </dt>
  <dd>
    오류 메시지. 비록 ECMA-262에서 {{jsxref("SyntaxError")}}는 반드시 자체
    <code>message</code> 속성을 제공해야한다고 명시했지만,
    <a href="/en-US/docs/Mozilla/Projects/SpiderMonkey">SpiderMonkey</a>는
    {{jsxref("Error.prototype.message")}}를 상속합니다.
  </dd>
  <dt>{{jsxref("Error.prototype.name", "SyntaxError.prototype.name")}}</dt>
  <dd>오류 이름. {{jsxref("Error")}}로부터 상속되었습니다.</dd>
  <dt>
    {{jsxref("Error.prototype.fileName", "SyntaxError.prototype.fileName")}}
  </dt>
  <dd>이 오류가 발생한 파일 경로. {{jsxref("Error")}}로부터 상속되었습니다.</dd>
  <dt>
    {{jsxref("Error.prototype.lineNumber", "SyntaxError.prototype.lineNumber")}}
  </dt>
  <dd>
    이 오류가 발생한 파일의 줄 수. {{jsxref("Error")}}로부터 상속되었습니다.
  </dd>
  <dt>
    {{jsxref("Error.prototype.columnNumber","SyntaxError.prototype.columnNumber")}}
  </dt>
  <dd>
    이 오류가 발생한 줄(행)에서의 열 위치. {{jsxref("Error")}}로부터 상속되었습니다.
  </dd>
  <dt>{{jsxref("Error.prototype.stack", "SyntaxError.prototype.stack")}}</dt>
  <dd>스택 트레이스. {{jsxref("Error")}}로부터 상속되었습니다.</dd>
</dl>
<h2 id="예제">예제</h2>
<h3 id="SyntaxError_잡기"><code>SyntaxError</code> 잡기</h3>
<pre class="brush: js">
try {
  eval('hoo bar');
} catch (e) {
  console.error(e instanceof SyntaxError);
  console.error(e.message);
  console.error(e.name);
  console.error(e.fileName);
  console.error(e.lineNumber);
  console.error(e.columnNumber);
  console.error(e.stack);
}
</pre>
<h3 id="SyntaxError_생성하기"><code>SyntaxError</code> 생성하기</h3>
<pre class="brush: js">
try {
  throw new SyntaxError('Hello', 'someFile.js', 10);
} catch (e) {
  console.error(e instanceof SyntaxError); // true
  console.error(e.message);                // Hello
  console.error(e.name);                   // SyntaxError
  console.error(e.fileName);               // someFile.js
  console.error(e.lineNumber);             // 10
  console.error(e.columnNumber);           // 0
  console.error(e.stack);                  // @debugger eval code:3:9
}
</pre>
<h2 id="명세" name="명세">명세</h2>
{{Specifications}}
<h2 id="브라우저_호환성">브라우저 호환성</h2>
<p>{{Compat}}</p>
<h2 id="같이_보기">같이 보기</h2>
<ul>
  <li>{{jsxref("Error")}}</li>
</ul>
 |