JavaScript: Difference between revisions

Content deleted Content added
No edit summary
Tag: possible vandalism
link to web platform in lead
 
(1,000 intermediate revisions by more than 100 users not shown)
Line 1:
{{Short description|High-level programming language}}
{{Use dmy dates|date=May 2016}}
{{Distinguish|Java (programming language)|Javanese script|ECMAScript}}
{{about|the family of punctuation marks|other uses|Bracket (disambiguation)}}
{{pp-semi-indef|small=yes}}
{{redirect2|Parenthesis|parenthetical|other uses|parenthesis (disambiguation)}}
{{Use dmy dates|date=March 2024}}
{{Redirect|( )|the Sigur Rós album|( ) (album)|other uses|( ) (disambiguation)}}
{{Infobox programming language
{{Punctuation marks||Brackets |variant1=( )|caption1=Round brackets or parentheses|variant2={ }|caption2=Curly brackets or braces|variant3=⟨ ⟩|caption3=Angle brackets or chevrons}}
| name = JavaScript
{{Contains special characters}}
| logo = <!-- Do not add unofficial logo, per [[Talk:JavaScript/Archive 5#Why is the unofficial logo present?]] -->
| logo alt =
| screenshot = JavaScript code.png
| screenshot caption = Screenshot of JavaScript source code
| paradigms = [[Multi-paradigm]]: [[Event-driven programming|event-driven]], [[Functional programming|functional]], [[Imperative programming|imperative]], [[Procedural programming|procedural]], [[Object-oriented programming|object-oriented]]
| memory management = [[Garbage collection (computer science)|Garbage collected]]
| family = [[ECMAScript]]
| designers = [[Brendan Eich]] of [[Netscape]] first; then others contributed to [[ECMAScript]] standard
| typing = [[Dynamic typing|Dynamic]], [[Strong and weak typing|weak]], [[Duck typing|duck]]
| scope = [[Scope (computer science)|lexical]]
| released = {{Start date and age|1995|12|04|df=y}}<ref name="press_release">{{Cite press release |url=https://wp.netscape.com/newsref/pr/newsrelease67.html |archive-url=https://web.archive.org/web/20070916144913/https://wp.netscape.com/newsref/pr/newsrelease67.html |archive-date=2007-09-16 |title=Netscape and Sun announce JavaScript, the Open, Cross-platform Object Scripting Language for Enterprise Networks and the Internet |date=December 4, 1995}}</ref>
| latest release version = {{wikidata|property|edit|reference|P548=Q2804309|P348}}
| latest release date = {{start date and age|{{wikidata|qualifier|single|P548=Q2804309|P348|P577}}}}
| latest preview version = {{wikidata|property|edit|reference|P548=Q51930650|P348}}
| latest preview date = {{start date and age|{{wikidata|qualifier|single|P548=Q51930650|P348|P577}}}}
| license =
| file extensions = <code>.js</code> • <code>.mjs</code> • <code>.cjs</code><ref name="node.js ECMAScript Modules Specification">{{cite web|url=https://github.com/nodejs/node-eps/blob/master/002-es-modules.md|title=nodejs/node-eps|website=GitHub|access-date=2018-07-05|archive-date=2020-08-29|archive-url=https://web.archive.org/web/20200829024713/https://github.com/nodejs/node-eps/blob/master/002-es-modules.md|url-status=live}}</ref>
| file format =
| website = {{URL|https://ecma-international.org/publications-and-standards/standards/ecma-262/}}
| implementations = [[V8 (JavaScript engine)|V8]], [[JavaScriptCore]], [[SpiderMonkey]];<br/>[[Chakra (JavaScript engine)|Chakra]] (deprecated)
| influenced by = [[Java (programming language)|Java]],<ref name="looklikejava">{{cite book |last1=Seibel |first1=Peter |date=September 16, 2009 |title=Coders at Work: Reflections on the Craft of Programming |publisher=Apress |isbn=978-1-4302-1948-4 |quote=Eich: The immediate concern at Netscape was it must look like Java. |url=https://books.google.com/books?id=nneBa6-mWfgC&q=The+immediate+concern+at+Netscape+was+it+must+look+like+Java.&pg=PA141 |access-date=December 25, 2018 |url-status=live |archive-url=https://web.archive.org/web/20201224233514/https://books.google.com/books?id=nneBa6-mWfgC&q=The+immediate+concern+at+Netscape+was+it+must+look+like+Java.&pg=PA141 |archive-date=December 24, 2020}}</ref><ref name="origin"/> [[Scheme (programming language)|Scheme]],<ref name="origin"/> [[Self (programming language)|Self]],<ref>{{cite web |url=https://brendaneich.com/2008/04/popularity/ |title = Popularity – Brendan Eich}}</ref> [[AWK]],<ref>{{cite web |title=Brendan Eich: An Introduction to JavaScript, JSConf 2010 |website=[[YouTube]] |date=20 January 2013 |quote=Eich: "function", eight letters, I was influenced by AWK. |url=https://www.youtube.com/watch?v=1EyRscXrehw |access-date=November 25, 2019 |page=22m |url-status=live |archive-url=https://web.archive.org/web/20200829024704/https://www.youtube.com/watch?v=1EyRscXrehw |archive-date=August 29, 2020}}</ref> [[HyperTalk]]<ref>{{cite book |last1=Eich |first1=Brendan |author1-link=Brendan Eich |chapter=Foreword |editor1-last=Goodman |editor1-first=Danny |editor1-link=Danny Goodman |year=1998 |title=JavaScript Bible |edition=3rd |publisher=[[John Wiley & Sons]] |isbn=0-7645-3188-3 |lccn=97078208 |oclc=38888873 |ol=712205M |url-access=registration |url=https://archive.org/details/javascriptbible000good}}</ref>
| influenced = [[ActionScript]], [[ArkTS]], [[AssemblyScript]], [[CoffeeScript]], [[Dart (programming language)|Dart]], [[Haxe]], [[JS++]], [[Opa (programming language)|Opa]], [[TypeScript]]
| wikibooks = JavaScript
}}
 
'''JavaScript''' ('''JS'''){{efn|{{IPAc-en|ˈ|dʒ|ɑː|v|ə|s|k|r|ɪ|p|t|audio=LL-Q1860 (eng)-Flame, not lame-JavaScript.wav}}}} is a [[programming language]] and core technology of the [[web platform]], alongside [[HTML]] and [[CSS]]. <!--don't add dating or decimals: it'll remain 99% indefinitely-->Ninety-nine percent of [[website]]s on the [[World Wide Web]] use JavaScript on the [[Client (computing)|client]] side for [[Web page|webpage]] behavior.<ref name="deployedstats">{{cite web |title=Usage Statistics of JavaScript as Client-side Programming Language on Websites |url=https://w3techs.com/technologies/details/cp-javascript |access-date=2024-02-27 |website=W3Techs }}</ref>
A '''bracket''' is a tall [[punctuation]] mark typically used in matched pairs within text, to set apart or interject other text. The matched pair is best described as ''opening'' and ''closing''<ref>''UAX #9: Unicode Bidirectional Algorithm'', [http://www.unicode.org/reports/tr9/#Paired_Brackets 3.1.3 Paired Brackets]</ref>. Less formally, in a left-to-right context, it may be described as ''left'' and ''right'', and in a right-to-left context, as ''right'' and ''left''.
 
[[Web browser]]s have a dedicated [[JavaScript engine]] that executes the client [[Source code|code]]. These engines are also utilized in some [[Server (computing)|servers]] and a variety of [[Application software|apps]]. The most popular [[runtime system]] for non-browser usage is [[Node.js]]{{cn|date=August 2025}}.
Forms include round (also called "parentheses"), square, curly (also called "braces"), and angle brackets (also called "chevrons"); and various other pairs of symbols.
 
JavaScript is a [[High-level programming language|high-level]], often [[Just-in-time compilation|just-in-time–compiled]] language that conforms to the [[ECMAScript]] standard.<ref name="tc39">{{cite web|title=ECMAScript 2020 Language Specification|url=https://tc39.es/ecma262/#sec-overview|url-status=live|archive-url=https://web.archive.org/web/20200508053013/https://tc39.es/ecma262/#sec-overview|archive-date=2020-05-08|access-date=2020-05-08}}</ref> It has [[dynamic typing]], [[Prototype-based programming|prototype-based]] [[object-oriented programming|object-orientation]], and [[first-class function]]s. It is [[Programming paradigm|multi-paradigm]], supporting [[Event-driven programming|event-driven]], [[functional programming|functional]], and [[imperative programming|imperative]] [[programming paradigm|programming styles]]. It has [[application programming interface]]s (APIs) for working with text, dates, [[regular expression]]s, standard [[data structure]]s, and the [[Document Object Model]] (DOM).
In addition to referring to the class of all types of brackets, the unqualified word ''bracket'' is most commonly used to refer to a specific type of bracket: in modern American usage this is usually the square bracket and in modern British usage this is usually the round bracket.
 
The ECMAScript standard does not include any [[input/output]] (I/O), such as [[computer network|networking]], [[data storage|storage]], or [[computer graphics|graphics]] facilities. In practice, the web browser or other runtime system provides JavaScript APIs for I/O.
 
Although [[Java (programming language)|Java]] and JavaScript are similar in name and [[Syntax (programming languages)|syntax]], the two languages are distinct and differ greatly in design.
 
== History ==
=== Creation at Netscape ===
The first popular [[web browser]] with a [[graphical user interface]], [[Mosaic (web browser)|Mosaic]], was released in 1993. The lead developers of Mosaic then founded the [[Netscape]] corporation, which released a more polished browser, [[Netscape Navigator]], in 1994. This quickly became the most-used.<ref>{{cite web|url=https://www.mwdwebsites.com/nj-web-design-web-browsers.html|title=The Evolution of the Web Browsers|last=Enzer|first=Larry|date=August 31, 2018|website=Monmouth Web Developers|access-date=August 31, 2018|archive-date=August 31, 2018|archive-url=https://web.archive.org/web/20180831174847/https://www.mwdwebsites.com/nj-web-design-web-browsers.html|url-status=dead}}</ref>
 
During these formative years of the Web, [[web page]]s could only be static, lacking the capability for dynamic behavior after the page was loaded in the browser. There was a desire in the flourishing web development scene to remove this limitation, so in 1995, Netscape decided to add a [[programming language]] to Navigator. They pursued two routes to achieve this: collaborating with [[Sun Microsystems]] to embed the [[Java (programming language)|Java]] language, while also hiring [[Brendan Eich]] to embed the [[Scheme (programming language)|Scheme]] language.<ref name="origin">{{cite web|url=https://exploringjs.com/es5/ch04.html|title=Chapter 4. How JavaScript Was Created|website=speakingjs.com|access-date=2017-11-21|archive-date=2020-02-27|archive-url=https://web.archive.org/web/20200227184037/https://speakingjs.com/es5/ch04.html|url-status=live}}</ref>
Chevrons (< >) were the earliest type of bracket to appear in [[written English]]. [[Desiderius Erasmus]] coined the term ''lunula'' to refer to the rounded parentheses (), recalling the shape of the crescent [[moon]].<ref>Truss, Lynne. ''Eats, Shoots & Leaves'', 2003. p. 161. {{ISBN|1-59240-087-6}}.</ref>
 
The goal was a "language for the masses",<ref name="EichVideo" /> "to help nonprogrammers create dynamic, interactive [[website|Web sites]]".<ref>"Netscape Communications Corp.", Browser enhancements. Encyclopædia Britannica 2006 Ultimate Reference Suite DVD</ref> Netscape management soon decided that the best option was for Eich to devise a new language, with syntax similar to Java and less like Scheme or other extant [[scripting language]]s.<ref name="looklikejava" /><ref name="origin" /> Although the new language and its [[Interpreter (computing)|interpreter]] implementation were called LiveScript when first shipped as part of a Navigator [[beta software|beta]] in September 1995, the name was changed to JavaScript for the official release in December.<ref name="origin" /><ref name="press_release" /><ref name="techvision">{{cite web | archive-url=https://web.archive.org/web/20080208124612/https://wp.netscape.com/comprod/columns/techvision/innovators_be.html | archive-date=February 8, 2008 | title=TechVision: Innovators of the Net: Brendan Eich and JavaScript | url=https://wp.netscape.com/comprod/columns/techvision/innovators_be.html }}</ref><ref name="wired2024">{{cite magazine |last1=Han |first1=Sheon |title=JavaScript Runs the World—Maybe Even Literally |url=https://www.wired.com/story/javascript-runs-the-world-maybe-literally/ |magazine=Wired |date=4 March 2024 |access-date=21 August 2024}}</ref>
==Names for various bracket symbols==
Some of the following names are regional or contextual.
 
The choice of the ''JavaScript'' name has caused confusion, implying that it is directly related to Java. At the time, the [[Dot-com bubble|dot-com boom]] had begun and Java was a popular new language, so Eich considered the JavaScript name a marketing ploy by Netscape.<ref name="EichVideo">{{Citation|last=Fin JS|title=Brendan Eich&nbsp;– CEO of Brave|date=June 17, 2016|url=https://www.youtube.com/watch?v=XOmhtfTrRxc |website=YouTube |access-date=February 7, 2018 }}</ref>
* (&nbsp;) &ndash; parentheses, brackets (UK, Canada, New Zealand, South Africa and Australia), parens, round brackets, soft brackets, first brackets or circle brackets
* [&nbsp;] &ndash; square brackets, closed brackets, hard brackets, second brackets, crotchets,<ref>Smith, John. ''The printer’s grammar: containing a concise history of the origin of printing; Also, an examination of the superficies, gradation, and properties of The different sizes of types cast by letter founders; Various Tables of Calculation; Models of Letter Cases; Schemes for casting off Copy and Imposing; and many other Requisites for attaining a perfect Knowledge both in the Theory and Practice of the Art of Printing. With directions to authors, compilers, &c. How to Prepare Copy, and to Correct their own Proofs. Chiefly collected from SMITH’s edition. To which are added directions for pressmen, &c. The whole calculated for the Service of All who have any Concern in the Letter Press.'' p. 84.</ref> or brackets (US)
* {&nbsp;} &ndash; braces are "two connecting marks used in printing"; and in music "to connect staves to be performed at the same time"<ref>Concise Oxford Dictionary, 10th Edition, Oxford University Press, Great Clarendon Street, Oxford OX2 2DP, UK</ref> (UK and US), French brackets, curly brackets, definite brackets, swirly brackets, curly braces, birdie brackets, Scottish brackets, squirrelly brackets, gullwings, seagulls, squiggly brackets, twirly brackets, Tuborg brackets (DK), accolades (NL), pointy brackets, third brackets, fancy brackets, M Brace.
* ⟨&nbsp;⟩ &ndash; pointy brackets, angle brackets, triangular brackets, diamond brackets, tuples, or chevrons
* &lt;&nbsp;&gt; &ndash; inequality signs, pointy brackets, or brackets. Sometimes referred to as ''angle brackets'', in such cases as [[HTML]] markup. Occasionally known as ''broken brackets'' or ''brokets''.<ref>{{cite web|url=http://catb.org/jargon/html/B/broket.html |title=broket |publisher=Catb.org |date= |accessdate=2013-02-13}}</ref>
* ⸤ ⸥; 「 」 &ndash; corner brackets
* ⟦&nbsp;⟧ &ndash; double square brackets, white square brackets
* 〔&nbsp;〕 &ndash; tortoise shell brackets
* Guillemets, ‹&nbsp;› and «&nbsp;», are sometimes referred to as chevrons or [double] angle brackets.<ref name=msterm>{{cite web |url=https://www.microsoft.com/language/en-us/Search.aspx?sString=chevron&langID=de-de |title=Terminology Search - Microsoft |website=Microsoft Language Portal - Terminology Collection|date= |author= |accessdate= 21 November 2016}}</ref>
 
=== Adoption by Microsoft ===
== Typography ==
[[Microsoft]] debuted [[Internet Explorer]] in 1995, leading to a [[browser war]] with Netscape. On the JavaScript front, Microsoft created its own [[Interpreter (computing)|interpreter]] called [[JScript]].<ref name="sjsch5">{{cite web |title=Chapter 5. Standardization: ECMAScript |url=https://speakingjs.com/es5/ch05.html |website=speakingjs.com |access-date=1 November 2021 |archive-date=1 November 2021 |archive-url=https://web.archive.org/web/20211101184346/http://speakingjs.com/es5/ch05.html |url-status=dead }}</ref>
 
Microsoft first released JScript in 1996, alongside initial support for [[CSS]] and extensions to [[HTML]]. Each of these [[implementation]]s was noticeably different from their counterparts in [[Netscape Navigator]].<ref name="O'Reilly-2001">{{cite web |url=https://archive.oreilly.com/pub/a/javascript/2001/04/06/js_history.html |title=JavaScript, How Did We Get Here? |last=Champeon |first=Steve |date=April 6, 2001 |website=oreilly.com |access-date=July 16, 2016 |archive-url=https://web.archive.org/web/20160719020828/https://archive.oreilly.com/pub/a/javascript/2001/04/06/js_history.html |archive-date=July 19, 2016 |url-status=dead}}</ref><ref>{{cite web |url=https://news.microsoft.com/1996/05/29/microsoft-internet-explorer-3-0-beta-now-available/ |title=Microsoft Internet Explorer 3.0 Beta Now Available |publisher=Microsoft |date=May 29, 1996 |website=microsoft.com |access-date=July 16, 2016 |archive-date=November 24, 2020 |archive-url=https://web.archive.org/web/20201124154053/https://news.microsoft.com/1996/05/29/microsoft-internet-explorer-3-0-beta-now-available/ |url-status=live }}</ref> These differences made it difficult for developers to make their websites work well in both browsers, leading to widespread use of "best viewed in Netscape" and "best viewed in Internet Explorer" logos for several years.<ref name="O'Reilly-2001" /><ref>{{cite web |url=https://www.technologizer.com/2010/09/16/the-unwelcome-return-of-best-viewed-with-internet-explorer/ |title=The Unwelcome Return of "Best Viewed with Internet Explorer" |last=McCracken |first=Harry |date=September 16, 2010 |website=technologizer.com |access-date=July 16, 2016 |archive-date=June 23, 2018 |archive-url=https://web.archive.org/web/20180623192402/https://www.technologizer.com/2010/09/16/the-unwelcome-return-of-best-viewed-with-internet-explorer/ |url-status=live }}</ref>
The characters ‹&nbsp;› and «&nbsp;», known as [[guillemet]]s or ''angular quote brackets'', are actually [[quotation mark glyphs]] used in several European languages.<ref>{{cite book|title=Merriam-Webster's Manual for Writers and Editors|year=1998|publisher=[[Merriam-Webster]]|page=149|url=https://books.google.com/books?id=7C6V9zRxSPkC&lpg=PA149&pg=PA149#v=onepage&&f=false|isbn=0-87779-622-X}} At [[Google Books]].</ref> Which one of each pair is the opening quote mark and which is the closing quote varies between languages.
 
=== The rise of JScript ===
Similarly, the corner-brackets 「&nbsp;」 are quotation marks used in East Asian languages (see [[Quotation mark#Chinese, Japanese and Korean quotation marks|Quotation mark § Chinese, Japanese and Korean quotation marks]]).
{{Quote box|[[Brendan Eich]] later said of this period: "It's still kind of a [[sidekick]] language. It's considered slow or annoying. People do [[Pop-up ad|pop-ups]] or those scrolling messages in the old [[status bar]] at the bottom of your old [[web browser|browser]]."<ref name="EichVideo" />|width=30%}}
 
In November 1996, [[Netscape]] submitted JavaScript to [[Ecma International]], as the starting point for a standard specification that all browser vendors could conform to. This led to the official release of the first [[ECMAScript]] language specification in June 1997.
In English, typographers generally prefer to not set brackets in [[italics]], even when the enclosed text is italic.<ref>Robert Bringhurst, ''The Elements of Typographic Style'', §5.3.2.</ref> However, in other languages like German, if brackets enclose text in italics, they are usually set in italics too.<ref>{{cite book |last1=Forsmann |first1=Friedrich |last2=DeJong |first2=Ralf |date=2004 |title=Detailtypografie |trans-title=Detail Typography |language=German |___location=Mainz |publisher= Herrmann Schmidt |page=263 |isbn= 978-3874396424}}</ref>
 
The standards process continued for a few years, with the release of ECMAScript 2 in June 1998 and ECMAScript 3 in December 1999. Work on ECMAScript 4 began in 2000.<ref name="sjsch5" />
== Types and uses ==
 
However, the effort to fully standardize the language was undermined by Microsoft gaining an increasingly dominant position in the browser market. By the early 2000s, [[Internet Explorer]]'s market share reached 95%.<ref name="searchenginejournal.com">{{cite news |last1=Baker |first1=Loren |date=November 24, 2004 |url=https://www.searchenginejournal.com/mozilla-firefox-internet-browser-market-share-gains-to-74/1082/ |title=Mozilla Firefox Internet Browser Market Share Gains to 7.4% |work=Search Engine Journal |access-date=May 8, 2021 |archive-date=May 7, 2021 |archive-url=https://web.archive.org/web/20210507013607/https://www.searchenginejournal.com/mozilla-firefox-internet-browser-market-share-gains-to-74/1082/ |url-status=live}}</ref> This meant that [[JScript]] became the de facto standard for [[client-side scripting]] on the Web.
=== Parentheses {{Anchor|Parenthesis}} ===
<!-- <onlyinclude> </onlyinclude> --> <!-- only include tag to avoid transclusion of the article bracket when someone writes this {{:)}}or {{:(}} -->
{{dablink|Various terms redirect here; for other uses, see [[Parenthesis (disambiguation)]], [[Paren (disambiguation)]], [[( ) (disambiguation)]], [[Parenthetical referencing]], and [[Parenthetical Girls]]}}
{{dablink|Due to [[Wikipedia:Naming conventions (technical restrictions)|technical restrictions]], titles like "<tt>:)</tt>" redirect here. For typographical portrayals of faces, see [[Emoticon]].}}
{{Wiktionary|parenthesis|( )}}
 
Microsoft initially participated in the standards process and implemented some proposals in its JScript language, but eventually it stopped collaborating on ECMA work. Thus ECMAScript 4 was mothballed.
====Usage in writing====
Parentheses {{IPAc-en|p|ə|ˈ|r|ɛ|n|θ|ᵻ|s|iː|z}} (singular, parenthesis {{IPAc-en|p|ə|ˈ|r|ɛ|n|θ|ᵻ|s|ᵻ|s}}) (also called simply brackets, or round brackets, curved brackets, oval brackets, stalls or, colloquially, parens {{IPAc-en|p|ə|ˈ|r|ɛ|n|z}}) contain material that serves to clarify (in the manner of a [[gloss (annotation)|gloss]]) or is aside from the main point.<ref>{{cite web|last=Straus|first=Jane|author-link=Jane Straus|title=Parentheses&nbsp;— Punctuation Rules|url=http://www.grammarbook.com/punctuation/parens.asp|work=The Blue Book of Grammar and Punctuation|publisher=grammarbook.com|accessdate=18 April 2014}}</ref> A milder effect may be obtained by using a pair of commas as the [[delimiter]], though if the sentence contains commas for other purposes, visual confusion may result.
 
=== Growth and standardization ===
In American usage, parentheses are usually considered separate from other brackets, and calling them "brackets" is unusual.
{{Plain image with caption|Logo of TC39.svg|Logo of [[Ecma International]] Technical Committee 39 who is responsible for maintaining the standard|150px}}
During the period of [[Internet Explorer]] dominance in the early 2000s, client-side scripting was stagnant. This started to change in 2004, when the successor of Netscape, [[Mozilla]], released the [[Firefox]] browser. Firefox was well received by many, taking significant market share from Internet Explorer.<ref>{{cite news |url=https://news.bbc.co.uk/2/hi/business/4508897.stm |title=The assault on software giant Microsoft |last=Weber |first=Tim |date=May 9, 2005 |work=[[BBC News]] |archive-url=https://web.archive.org/web/20170925233936/https://news.bbc.co.uk/2/hi/business/4508897.stm |archive-date=September 25, 2017}}</ref>
 
In 2005, Mozilla joined ECMA International, and work started on the [[ECMAScript for XML]] (E4X) standard. This led to Mozilla working jointly with [[Macromedia]] (later acquired by [[Adobe Systems]]), who were implementing E4X in their ActionScript 3 language, which was based on an ECMAScript 4 draft. The goal became standardizing ActionScript 3 as the new ECMAScript 4. To this end, Adobe Systems released the [[Tamarin (software)|Tamarin]] implementation as an [[Open-source model|open source]] project. However, Tamarin and ActionScript 3 were too different from established client-side scripting, and without cooperation from Microsoft, ECMAScript 4 never reached fruition.
Parentheses may be used in formal writing to add supplementary information, such as "Sen. John McCain (R-Arizona) spoke at length". They can also indicate shorthand for "[[uncertain plural|either singular or plural]]" for nouns, e. g. "the claim(s)". It can also be used for [[gender neutral language]], especially in languages with [[grammatical gender]], e. g. "(s)he agreed with his (her) physician".<ref>[[Slash (punctuation)#Gender-neutrality in Spanish and Portuguese]]</ref>
 
Meanwhile, very important developments were occurring in open-source communities not affiliated with ECMA work. In 2005, [[Jesse James Garrett]] released a white paper in which he coined the term [[Ajax (programming)|Ajax]] and described a set of technologies, of which JavaScript was the backbone, to create [[web application]]s where data can be loaded in the background, avoiding the need for full page reloads. This sparked a renaissance period of JavaScript, spearheaded by open-source libraries and the communities that formed around them. Many new libraries were created, including [[jQuery]], [[Prototype JavaScript Framework|Prototype]], [[Dojo Toolkit]], and [[MooTools]].
Parenthetical phrases have been used extensively in informal writing and stream of consciousness literature. Examples include the southern American author [[William Faulkner]] (see ''[[Absalom, Absalom!]]'' and [[The Sound and the Fury#Part 2: June 2, 1910|the Quentin section of ''The Sound and the Fury'']]) as well as poet [[E. E. Cummings]].
 
[[Google]] debuted its [[Google Chrome|Chrome]] browser in 2008, with the [[V8 (JavaScript engine)|V8]] JavaScript engine that was faster than its competition.<ref>{{cite web|url=https://www.pcgameshardware.com/aid,687738/Big-browser-comparison-test-Internet-Explorer-vs-Firefox-Opera-Safari-and-Chrome-Update-Firefox-35-Final/Practice/|title=Big browser comparison test: Internet Explorer vs. Firefox, Opera, Safari and Chrome|work=PC Games Hardware|date=3 July 2009|publisher=Computec Media AG|access-date=June 28, 2010|archive-date=May 2, 2012|archive-url=https://web.archive.org/web/20120502043027/http://www.pcgameshardware.com/aid,687738/Big-browser-comparison-test-Internet-Explorer-vs-Firefox-Opera-Safari-and-Chrome-Update-Firefox-35-Final/Practice/|url-status=live}}</ref><ref>{{cite web | url=https://lifehacker.com/lifehacker-speed-tests-safari-4-chrome-2-and-more-5286869 | title=Lifehacker Speed Tests: Safari 4, Chrome 2 | first=Kevin | last=Purdy | work=[[Lifehacker]] | date=June 11, 2009 | access-date=May 8, 2021 | archive-date=April 14, 2021 | archive-url=https://web.archive.org/web/20210414095403/https://lifehacker.com/lifehacker-speed-tests-safari-4-chrome-2-and-more-5286869 | url-status=live }}</ref> The key innovation was [[just-in-time compilation]] (JIT),<ref>{{cite web|url=https://brendaneich.com/2008/08/tracemonkey-javascript-lightspeed/|title=TraceMonkey: JavaScript Lightspeed, Brendan Eich's Blog|access-date=July 22, 2020|archive-date=December 4, 2015|archive-url=https://web.archive.org/web/20151204091540/https://brendaneich.com/2008/08/tracemonkey-javascript-lightspeed/|url-status=live}}</ref> so other browser vendors needed to overhaul their engines for JIT.<ref>{{cite magazine |title=Mozilla asks, 'Are we fast yet?' |url=https://www.wired.com/2010/09/mozilla-asks-are-we-fast-yet/ |magazine=Wired |access-date=January 18, 2019 |archive-date=June 22, 2018 |archive-url=https://web.archive.org/web/20180622213244/https://www.wired.com/2010/09/mozilla-asks-are-we-fast-yet/ |url-status=live }}</ref>
Parentheses have historically been used where the [[Em dash|dash]] is currently used in alternatives, such as "parenthesis)(parentheses". Examples of this usage can be seen in editions of ''[[A Dictionary of Modern English Usage|Fowler's]]''.
 
In July 2008, these disparate parties came together for a conference in [[Oslo]]. This led to the eventual agreement in early 2009 to combine all relevant work and drive the language forward. The result was the ECMAScript 5 standard, released in December 2009.
Parentheses may be nested (generally with one set (such as this) inside another set). This is not commonly used in formal writing (though sometimes other brackets [especially square brackets] will be used for one or more inner set of parentheses [in other words, secondary {or even tertiary} phrases can be found within the main parenthetical sentence]).<ref>{{cite web|last=Fogarty|first=Mignon|title=Parentheses, Brackets, and Braces|url=http://grammar.quickanddirtytips.com/parentheses-brackets-and-braces.aspx|publisher=Quick and Dirty Tips|accessdate=27 March 2011}}</ref>
 
=== Reaching maturity ===
Any punctuation inside parentheses or other brackets is independent of the rest of the text: "Mrs. Pennyfarthing (What? Yes, that was her name!) was my landlady." In this usage, the explanatory text in the parentheses is a [[Parenthesis (rhetoric)|parenthesis]]. (Parenthesized text is usually short and within a single sentence. Where several sentences of supplemental material are used in parentheses the final [[full stop]] would be within the parentheses, or simply omitted. Again, the parenthesis implies that the meaning and flow of the text is supplemental to the rest of the text and the whole would be unchanged were the parenthesized sentences removed.)
Ambitious work on the language continued for several years, culminating in an extensive collection of additions and refinements being formalized with the publication of [[ECMAScript 6]] in 2015.<ref>{{cite web |url=https://es6-features.org/ |title=ECMAScript 6: New Features: Overview and Comparison |website=es6-features.org |access-date=March 19, 2018 |archive-date=March 18, 2018 |archive-url=https://web.archive.org/web/20180318064130/https://es6-features.org/ |url-status=usurped }}</ref>
 
The creation of [[Node.js]] in 2009 by [[Ryan Dahl]] sparked a significant increase in the usage of JavaScript outside of web browsers. Node combines the [[V8 (JavaScript engine)|V8]] engine, an [[event loop]], and [[Input/output|I/O]] [[Application programming interface|APIs]], thereby providing a stand-alone JavaScript runtime system.<ref>[https://books.google.com/books?id=ZH6bpbcrlvYC&q=nodejs Professional Node.js: Building JavaScript Based Scalable Software] {{Webarchive|url=https://web.archive.org/web/20170324021220/https://books.google.com/books?id=ZH6bpbcrlvYC&printsec=frontcover&dq=nodejs&hl=en&sa=X#v=onepage&q=nodejs&f=false |date=2017-03-24 }}, John Wiley & Sons, 01-Oct-2012</ref><ref name="b3">[https://books.google.com/books?id=KGt-FxUEj48C&dq=nodejs&pg=PT24 Sams Teach Yourself Node.js in 24 Hours] {{Webarchive|url=https://web.archive.org/web/20170323192039/https://books.google.com/books?id=KGt-FxUEj48C&pg=PT24&dq=nodejs&hl=en&sa=X#v=onepage&q=nodejs&f=false |date=2017-03-23 }}, Sams Publishing, 05-Sep-2012</ref> As of 2018, Node had been used by millions of developers,<ref>{{cite web |last1=Lawton |first1=George |title=The secret history behind the success of npm and Node |url=https://www.theserverside.com/blog/Coffee-Talk-Java-News-Stories-and-Opinions/The-secret-history-behind-the-success-of-npm-and-Node |website=TheServerSide |access-date=2 August 2021 |date=19 July 2018 |archive-date=2 August 2021 |archive-url=https://web.archive.org/web/20210802165613/https://www.theserverside.com/blog/Coffee-Talk-Java-News-Stories-and-Opinions/The-secret-history-behind-the-success-of-npm-and-Node |url-status=live }}</ref> and [[npm (software)|npm]] had the most modules of any [[package manager]] in the world.<ref>{{cite web |last1=Brown |first1=Paul |title=State of the Union: npm |url=https://www.linux.com/news/state-union-npm/ |website=Linux.com |access-date=2 August 2021 |date=13 January 2017 |archive-date=2 August 2021 |archive-url=https://web.archive.org/web/20210802165614/https://www.linux.com/news/state-union-npm/ |url-status=live }}</ref>
In more formal usage, "[[Parenthesis (rhetoric)|parenthesis]]" may refer to the entire bracketed text, not just to the punctuation marks used (so all the text in this set of round brackets may be said to be "a [[parenthesis (rhetoric)|parenthesis]]", "a parenthetical", or "a parenthetical phrase").<ref>{{cite web|url=http://www.thefreedictionary.com/parenthetical |title=The Free Online Dictionary |publisher=Thefreedictionary.com |date= |accessdate=2013-02-13}}</ref>
 
The ECMAScript draft specification is currently maintained openly on [[GitHub]],<ref name=branscombe /> and editions are produced via regular annual snapshots.<ref name=branscombe>{{cite web |url=https://thenewstack.io/whats-new-es2016/ |title=JavaScript Standard Moves to Yearly Release Schedule; Here is What's New for ES16 |last=Branscombe |first=Mary |date=2016-05-04 |access-date=2021-01-15 |work=The New Stack |archive-date=2021-01-16 |archive-url=https://web.archive.org/web/20210116181757/https://thenewstack.io/whats-new-es2016/ |url-status=live }}</ref> Potential revisions to the language are vetted through a comprehensive proposal process.<ref>{{cite web|url=https://tc39.es/process-document/|title=The TC39 Process|publisher=Ecma International|work=tc39.es|access-date=2021-01-15|archive-date=2021-02-07|archive-url=https://web.archive.org/web/20210207105535/https://tc39.es/process-document/|url-status=live}}</ref><ref>{{cite web |url=https://github.com/tc39/proposals/blob/master/README.md |title=ECMAScript proposals |access-date=2021-01-15 |publisher=TC39 |archive-date=2020-12-04 |archive-url=https://web.archive.org/web/20201204221147/https://github.com/tc39/proposals/blob/master/README.md |url-status=live }}</ref> Now, instead of edition numbers, developers check the status of upcoming features individually.<ref name=branscombe />
====Usage in enumerations====
;Unpaired parenthesis
Lower-case [[Latin letters]] used as indexes, rather than [[bullet (typography)|bullet]]s or numbers, followed by an unpaired parenthesis, are used in ordered [[wiktionary:list|list]]s especially in:
#[[education]]al testing,
#technical writing and diagrams,
#[[market research]], and
#[[elections]].{{citation needed|date=February 2018}}
 
The current JavaScript ecosystem has many [[List of JavaScript libraries|libraries]] and [[web framework|frameworks]], established programming practices, and substantial usage of JavaScript outside of web browsers.<ref name="wired2024" /> Plus, with the rise of [[single-page application]]s and other JavaScript-heavy websites, several [[source-to-source compiler|transpilers]] have been created to aid the development process.<ref name="transpilers" />
====Usage as antisemitic symbol====
Since 2014, [[antisemite]]s have used [[triple parentheses]] around the names of people to denote them as Jewish.<ref name=mic>{{cite news|last1=Fleishman|first1=Cooper|last2=Smith|first2=Anthony|title=(((Echoes))), Exposed: The Secret Symbol Neo-Nazis Use to Target Jews Online|url=https://mic.com/articles/144228/echoes-exposed-the-secret-symbol-neo-nazis-use-to-target-jews-online#.sS1GX29cQ|accessdate=4 June 2016|publisher=Mic|date=1 June 2016}}</ref>
 
== Trademark ==
====Usage in mathematics====
"JavaScript" is a [[trademark]] of [[Oracle Corporation]] in the United States.<ref>{{cite web |date=1997-05-06 |title=U.S. Trademark Serial No. 75026640 |url=https://tsdr.uspto.gov/#caseNumber=75026640&caseType=SERIAL_NO&searchType=statusSearch |url-status=live |archive-url=https://web.archive.org/web/20210713022850/https://tsdr.uspto.gov/#caseNumber=75026640&caseType=SERIAL_NO&searchType=statusSearch |archive-date=2021-07-13 |access-date=2021-05-08 |website=uspto.gov |publisher=[[United States Patent and Trademark Office]]}}</ref><ref>{{cite web |title=Legal Notices |url=https://www.oracle.com/legal/trademarks.html |url-status=live |archive-url=https://web.archive.org/web/20210605142505/https://www.oracle.com/legal/trademarks.html |archive-date=2021-06-05 |access-date=2021-05-08 |website=oracle.com |publisher=[[Oracle Corporation]]}}</ref> The trademark was originally issued to [[Sun Microsystems]] on 6 May 1997, and was transferred to Oracle when they acquired Sun in 2009.<ref>{{Cite news |title=Oracle to buy Sun in $7.4-bn deal | newspaper=The Economic Times |url=https://economictimes.indiatimes.com/tech/software/oracle-to-buy-sun-in-7-4-bn-deal/articleshow/4427747.cms | date = 21 April 2009}}</ref><ref>{{Cite news |title=Oracle urged again to give up JavaScript trademark |work=The Register |url=https://www.theregister.com/2024/09/17/oracle_urged_to_surrender_javascript_trademark/ |date=17 September 2024 |last1=Claburn |first1=Thomas |access-date=2 February 2025}}</ref>
Parentheses are used in [[mathematical notation]] to indicate grouping, often inducing a different [[order of operations]]. For example: in the usual order of algebraic operations, {{math|2 + 3 × 4}} equals 14, since the multiplication is done before the addition. However, {{math|(2 + 3) × 4}} equals 20, because the parentheses override normal precedence, causing the addition to be done first. Some authors follow the convention in mathematical equations that, when parentheses have one level of nesting, the inner pair are parentheses and the outer pair are square brackets. Example:
 
A letter was circulated in September 2024, spearheaded by [[Ryan Dahl]], calling on Oracle to free the JavaScript trademark.<ref>{{Cite news|last=Krill|first=Paul|date=September 20, 2024|title=JavaScript community challenges Oracle's JavaScript trademark|url=https://www.infoworld.com/article/3532457/javascript-community-challenges-oracles-javascript-trademark.html|work=InfoWorld}}</ref> [[Brendan Eich]], the original creator of JavaScript, was among the over 14,000 signatories who supported the initiative.
:<math>[(2 + 3) \times 4]^2 = 400.</math>
 
== Website client-side usage ==
A related convention is that when parentheses have two levels of nesting, curly brackets (braces) are the outermost pair. Following this convention, when more than three levels of nesting are needed, often a cycle of parentheses, square brackets, and curly brackets will continue. This helps to distinguish between one such level and the next.<ref>{{cite web|url=http://math.about.com/od/mathhelpandtutorials/fl/Parenthesis-Braces-and-Brackets.html |title=Archived copy |accessdate=2014-08-01 |deadurl=yes |archiveurl=https://archive.is/20140806203819/http://math.about.com/od/mathhelpandtutorials/fl/Parenthesis-Braces-and-Brackets.html |archivedate=6 August 2014 }}</ref>
JavaScript is the dominant [[client-side]] [[scripting language]] of the Web, with 99% of all [[website]]s using it for this purpose.<ref name="deployedstats" /> Scripts are embedded in or included from [[HTML]] documents and interact with the [[Document Object Model|DOM]].
 
All major [[web browser]]s have a built-in [[JavaScript engine]] that executes the [[Source code|code]] on the user's device.
Parentheses are also used to set apart the [[Parameter|argument]]s in mathematical [[Function (mathematics)|function]]s. For example, {{math|''f''(''x'')}} is the function ''{{math|f}}'' applied to the [[Variable (mathematics)|variable]] ''{{math|x}}''. In [[coordinate system]]s parentheses are used to denote a set of coordinates; so in the [[Cartesian coordinate system]] {{math|(4, 7)}} may represent the point located at 4 on the ''x''-axis and 7 on the ''y''-axis.
 
=== Examples of scripted behavior ===
Parentheses may also be used to represent a [[binomial coefficient]].
* Loading new [[web page]] content without reloading the page, via [[Ajax (programming)|Ajax]] or a [[WebSocket]]. For example, [[user (computing)|users]] of [[social media]] can send and receive messages without leaving the current page.
* Web page animations, such as fading objects in and out, resizing, and moving them.
* Playing [[browser game]]s.
* Controlling the [[Media player software|playback]] of [[streaming media]].
* Generating [[pop-up ad]]s or alert boxes.
* [[Data validation|Validating]] input values of a [[Form (HTML)|web form]] before the data is sent to a [[web server]].
* Logging data about the user's behavior then sending it to a server. The website owner can use this data for [[Web analytics|analytics]], [[ad tracking]], and [[personalization]].
*Redirecting a user to another page.
* Storing and retrieving data on the user's device, via the [[web storage|storage]] or [[Indexed Database API|IndexedDB]] standards.
 
=== Libraries and frameworks ===
====Usage in programming languages====
Over 80% of websites use a third-party JavaScript [[Library (computing)|library]] or [[web framework]] as part of their client-side scripting.<ref name="lib_usage">{{cite web|url=https://w3techs.com/technologies/overview/javascript_library|title=Usage statistics of JavaScript libraries for websites|website=W3Techs|access-date=2021-04-09}}</ref>
Parentheses are included in the syntaxes of many [[programming languages]]. Typically needed to denote an argument; to tell the compiler what data type the Method/Function needs to look for first in order to initialise. In some cases, such as in [[LISP]], parentheses are a fundamental construct of the language.
 
[[jQuery]] is by far the most-used.<ref name="lib_usage" /> Other notable ones include <!--alphabetically is fair here-->[[Angular (web framework)|Angular]], [[Bootstrap (front-end framework)|Bootstrap]], [[Lodash]], [[Modernizr]], [[React (software)|React]], [[Underscore.js|Underscore]], and [[Vue.js|Vue]].<ref name="lib_usage" /> Multiple options can be used in conjunction, such as jQuery and Bootstrap.<ref>{{cite web |title=Using jQuery with Bootstrap |url=https://clouddevs.com/jquery/web-projects-with-bootstrap/ |website=clouddevs.com |date=10 June 2019 |access-date=17 March 2024}}</ref>
====Usage in other scientific fields====
Parentheses are used in [[chemistry]] to denote a [[polyatomic ion]].{{citation needed|date=February 2018}}
 
However, the term "Vanilla JS" was coined for websites not using any libraries or frameworks at all, instead relying entirely on standard JavaScript functionality.<ref>{{cite web |date=2020-06-16 |title=Vanilla JS |url=https://vanilla-js.com/ |url-status=live |archive-url=https://web.archive.org/web/20200616052335/https://vanilla-js.com/ |archive-date=June 16, 2020 |access-date=June 17, 2020 |website=vanilla-js.com}}</ref>
=== Square brackets {{Anchor|square bracket}} ===
{{Wiktionary|square bracket}}
 
== Other usage{{anchor|Server-side_JavaScript|Uses_outside_web_pages}} ==
====Usage in journalism====
The use of JavaScript has expanded beyond its [[web browser]] roots. [[JavaScript engine]]s are now embedded<!--don't link Embedded system here--> in a variety of other software systems, both for [[server-side]] website deployments and non-browser [[application software|applications]].
Square brackets—also called crotchets or simply brackets (US)—are mainly used to insert explanatory material or to mark where a passage was omitted from an original material by someone other than the original author, or to mark modifications in quotations.<ref>''The Chicago Manual of Style, 15th ed.'', The University of Chicago Press, 2003, §6.104</ref>
 
Initial attempts at promoting server-side JavaScript usage were [[Netscape Enterprise Server]] and [[Microsoft]]'s [[Internet Information Services]],<ref>{{cite web |date=December 11, 1998 |title=Server-Side JavaScript Guide |url=https://docs.oracle.com/cd/E19957-01/816-6411-10/contents.htm |url-status=live |archive-url=https://web.archive.org/web/20210311173120/https://docs.oracle.com/cd/E19957-01/816-6411-10/contents.htm |archive-date=March 11, 2021 |access-date=May 8, 2021 |website=oracle.com |publisher=[[Oracle Corporation]]}}</ref><ref>{{cite web|last1=Clinick|first1=Andrew|title=Introducing JScript .NET|url=https://msdn.microsoft.com/en-us/library/ms974588.aspx|website=Microsoft Developer Network|publisher=Microsoft|access-date=April 10, 2018|date=July 14, 2000|quote=[S]ince the 1996 introduction of JScript version 1.0 ... we've been seeing a steady increase in the usage of JScript on the server—particularly in Active Server Pages (ASP)|archive-date=November 10, 2017|archive-url=https://web.archive.org/web/20171110201649/https://msdn.microsoft.com/en-us/library/ms974588.aspx|url-status=live}}</ref> but they were small niches.<ref name="2009server" /> Server-side usage eventually started to grow in the late 2000s, with the creation of [[Node.js]] and [[List of server-side JavaScript implementations|other approaches]].<ref name="2009server">{{cite web |url=https://readwrite.com/2009/12/17/server-side_javascript_back_with_a_vengeance/ |title=Server-Side JavaScript, Back with a Vengeance |date=December 17, 2009 |website=readwrite.com |access-date=July 16, 2016 |author=Mahemoff, Michael |archive-date=June 17, 2016 |archive-url=https://web.archive.org/web/20160617030219/https://readwrite.com/2009/12/17/server-side_javascript_back_with_a_vengeance/ |url-status=live }}</ref>
A bracketed [[ellipsis]], […], is often used to indicate omitted material: "I'd like to thank [several unimportant people] for their tolerance [...]"<ref>{{cite web|url=http://www.bartleby.com/68/60/960.html |title=Bartleby.com: Great Books Online -- Quotes, Poems, Novels, Classics and hundreds more |work=bartleby.com |deadurl=yes |archiveurl=https://web.archive.org/web/20080524214802/http://www.bartleby.com/68/60/960.html |archivedate=24 May 2008 |df=dmy }}</ref>
Bracketed comments inserted into a quote indicate when the original has been modified for clarity: "I appreciate it [the honor], but I must refuse", and "the future of psionics [see definition] is in doubt". Or one can quote the original statement "I hate to do laundry" with a (sometimes grammatical) modification inserted: He "hate[s] to do laundry".
 
[[Electron (software framework)|Electron]], [[Apache Cordova|Cordova]], [[React Native]], and other [[application framework]]s have been used to create many applications with behavior implemented in JavaScript. Other non-browser applications include [[Adobe Acrobat]] support for scripting [[PDF]] documents<ref>{{cite web |date=2009-08-07 |title=JavaScript for Acrobat |url=https://www.adobe.com/devnet/acrobat/javascript.html |url-status=live |archive-url=https://web.archive.org/web/20090807065130/https://www.adobe.com/devnet/acrobat/javascript.html |archive-date=August 7, 2009 |access-date=August 18, 2009 |website=adobe.com}}</ref> and [[GNOME Shell]] extensions written in JavaScript.<ref>{{cite web |last=treitter |date=2013-02-02 |title=Answering the question: "How do I develop an app for GNOME?" |url=https://treitter.livejournal.com/14871.html |url-status=live |archive-url=https://web.archive.org/web/20130211032900/https://treitter.livejournal.com/14871.html |archive-date=2013-02-11 |access-date=2013-02-07 |website=livejournal.com}}</ref>
Additionally, a small letter can be replaced by a capital one, when the beginning of the original text is omitted for [[succinctness]], for example, when referring to a [[verbose]] original: "To the extent that policymakers and elite opinion in general have made use of economic analysis at all, they have, as the saying goes, done so the way a drunkard uses a lamppost: for support, not illumination", it can be quoted succinctly as: "[P]olicymakers […] made use of economic analysis […] the way a drunkard uses a lamppost: for support, not illumination." When nested parentheses are needed, brackets are used as a substitute for the inner pair of parentheses within the outer pair.<ref>''The Chicago Manual of Style, 15th ed.'', The University of Chicago Press, 2003, §6.102 and §6.106</ref> When deeper levels of nesting are needed, convention is to alternate between parentheses and brackets at each level.
 
[[Oracle Corporation|Oracle]] used to provide [[Nashorn (JavaScript engine)| Nashorn]], a JavaScript interpreter, as part of their [[JDK|Java Development Kit (JDK)]] API library along with '''jjs''' a command line interpreter as of JDK version 8. It was removed in JDK 15. As a replacement Oracle offered GraalJS which can also be used with the [[OpenJDK]] which allows one to create and reference Java objects in JavaScript code and add runtime scripting in JavaScript to applications written in Java.<ref> {{cite web |last=Ponge |first=Julien |date=2018-04-19 |title=Oracle Nashorn: A Next-Generation JavaScript Engine for the JVM |website=oracle.com |url=https://www.oracle.com/technical-resources/articles/java/jf14-nashorn.html |publisher=Oracle Corporation |access-date=Feb 17, 2025}} </ref><ref>{{cite web |author=<!-- not stated --> |title=Migration Guide from Nashorn to GraalJS |url=https://www.graalvm.org/latest/reference-manual/js/NashornMigrationGuide/ |website=graalvm.org | access-date=Feb 17, 2025}} </ref><ref>{{cite web |author=<!-- not stated --> |title=GraalJS |url=https://www.graalvm.org/latest/reference-manual/js/ |website=|publisher=GraalVM |access-date=Feb 17, 2025}}</ref><ref>{{cite web |author=<!-- not stated --> |title=Java Interoperability | url=https://docs.oracle.com/en/graalvm/enterprise/21/docs/reference-manual/js/JavaInteroperability/|website=oracle.com|publisher=Oracle |access-date=Feb 17, 2025}}</ref>
Alternatively, empty square brackets can also indicate omitted material, usually single letter only. The original "Reading is also a process and it also changes you." can be rewritten in a quote as: It has been suggested that reading can "also change[] you".
 
JavaScript has been used in some [[embedded system]]s, usually by leveraging Node.js.<ref>{{cite web |title=Tessel 2... Leverage all the libraries of Node.JS to create useful devices in minutes with Tessel. |url=https://tessel.io/ |url-status=live |archive-url=https://web.archive.org/web/20210526212559/https://tessel.io/ |archive-date=2021-05-26 |access-date=2021-05-08 |website=tessel.io}}</ref><ref>{{cite web |title=Node.js Raspberry Pi GPIO Introduction |url=https://www.w3schools.com/nodejs/nodejs_raspberrypi_gpio_intro.asp |url-status=live |archive-url=https://web.archive.org/web/20210813192938/https://www.w3schools.com/nodejs/nodejs_raspberrypi_gpio_intro.asp |archive-date=2021-08-13 |access-date=2020-05-03 |website=w3schools.com}}</ref><ref>{{cite web |title=Espruino&nbsp;– JavaScript for Microcontrollers |url=https://www.espruino.com/ |url-status=live |archive-url=https://web.archive.org/web/20200501010722/https://www.espruino.com/ |archive-date=2020-05-01 |access-date=2020-05-03 |website=espruino.com}}</ref>
The bracketed expression "[[sic|[''sic'']]]" is used after a quote or reprinted text to indicate the passage appears exactly as in the original source, where it may otherwise appear that a mistake has been made in reproduction.
 
== Execution ==
In translated works, brackets are used to signify the same word or phrase in the original language to avoid ambiguity.<ref>''The Chicago Manual of Style, 15th ed.'', The University of Chicago Press, 2003, §6.105</ref>
=== JavaScript engine ===
For example: ''He is trained in the way of the open hand [karate].''
{{Excerpt|JavaScript engine}}
 
=== Runtime system ===
====Usage in proofreading====
A JavaScript engine must be embedded within a [[runtime system]] (such as a [[web browser]] or a standalone system) to enable scripts to interact with the broader environment. The runtime system includes the necessary APIs for [[input/output]] operations, such as [[computer network|networking]], [[data storage|storage]], and [[computer graphics|graphics]], and provides the ability to import scripts.
Brackets (called ''move-left symbols'' or ''move right symbols'') are added to the sides of text in [[proofreading]] to indicate changes in indentation:
 
JavaScript is a single-[[Thread (computing)|threaded]] language. The runtime processes [[Message (computer science)|messages]] from a [[Queue (abstract data type)|queue]] one at a time, and it calls a [[Subroutine|function]] associated with each new message, creating a [[call stack]] frame with the function's [[Parameter (computer programming)|arguments]] and [[local variable]]s. The call stack shrinks and grows based on the function's needs. When the call stack is empty upon function completion, JavaScript proceeds to the next message in the queue. This is called the [[event loop]], described as "run to completion" because each message is fully processed before the next message is considered. However, the language's [[Concurrency (computer science)|concurrency model]] describes the event loop as [[Asynchronous I/O|non-blocking]]: program I/O is performed using [[Event (computing)|events]] and [[Callback (computer programming)|callback functions]]. This means, for example, that JavaScript can process a mouse click while waiting for a database query to return information.<ref>{{cite web|url=https://developer.mozilla.org/en-US/docs/Web/JavaScript/EventLoop|title=Concurrency model and Event Loop|website=Mozilla Developer Network|access-date=August 28, 2015|archive-date=September 5, 2015|archive-url=https://web.archive.org/web/20150905045241/https://developer.mozilla.org/en-US/docs/Web/JavaScript/EventLoop|url-status=live}}</ref>
 
The notable standalone runtimes are [[Node.js]], [[Deno (software)|Deno]], and [[Bun (software)|Bun]].
 
== Features ==
The following features are common to all conforming ECMAScript implementations unless explicitly specified otherwise. The number of cited reserved words including keywords is 50–60 and varies depending on the implementation.
 
=== Imperative and structured ===
{{Main|Structured programming}}
 
JavaScript supports much of the [[structured programming]] syntax from [[C (computer language)|C]] (e.g., <code>if</code> statements, <code>while</code> loops, <code>switch</code> statements, <code>do while</code> loops, etc.). One partial exception is [[scope (computer science)|scoping]]: originally JavaScript only had [[function scoping]] with <code>var</code>; [[block scoping]] was added in ECMAScript 2015 with the keywords <code>let</code> and <code>[[const (computer programming)|const]]</code>. Like C, JavaScript makes a distinction between [[Expression (computer science)|expressions]] and [[Statement (computer science)|statements]]. One syntactic difference from C is [[Defensive semicolon|automatic semicolon insertion]], which allow semicolons (which terminate statements) to be omitted.<ref name="Flanagan2006">{{cite book|last=Flanagan|first=David|title=JavaScript: The Definitive Guide |url=https://books.google.com/books?id=2weL0iAfrEMC|date=August 17, 2006|publisher=[[O'Reilly Media, Inc.]]|isbn=978-0-596-55447-7|page=16|access-date=March 29, 2019|archive-date=August 1, 2020|archive-url=https://web.archive.org/web/20200801065235/https://books.google.com/books?id=2weL0iAfrEMC|url-status=live}}</ref>
 
=== Weakly typed ===
{{Further|Weakly typed}}
 
JavaScript is [[Strong and weak typing|weakly typed]], which means certain types are implicitly cast depending on the operation used.<ref name="casting_rules">{{cite web |last=Korolev |first=Mikhail |date=2019-03-01 |title=JavaScript quirks in one image from the Internet |url=https://dev.to/mkrl/javascript-quirks-in-one-image-from-the-internet-52m7 |url-status=live |archive-url=https://web.archive.org/web/20191028204723/https://dev.to/mkrl/javascript-quirks-in-one-image-from-the-internet-52m7 |archive-date=October 28, 2019 |access-date=October 28, 2019 |website=The DEV Community |language=en}}</ref>
 
* The binary <code>+</code> operator casts both operands to a string unless both operands are numbers. This is because the addition operator doubles as a concatenation operator
* The binary <code>-</code> operator always casts both operands to a number
* Both unary operators (<code>+</code>, <code>-</code>) always cast the operand to a number. However, <code>+</code> always casts to <code>Number</code> ([[Double-precision floating-point format|binary64]]) while <code>-</code> preserves <code>BigInt</code> ([[Arbitrary-precision arithmetic|integer]])<ref>{{cite web | url=https://github.com/tc39/proposal-bigint/blob/master/ADVANCED.md#dont-break-asmjs | title=Proposal-bigint/ADVANCED.md at master · tc39/Proposal-bigint | website=[[GitHub]] }}</ref>
 
Values are cast to strings like the following:<ref name="casting_rules" />
 
* Strings are left as-is
* Numbers are converted to their string representation
* Arrays have their elements cast to strings after which they are joined by commas (<code>,</code>)
* Other objects are converted to the string <code>[object Object]</code> where <code>Object</code> is the name of the constructor of the object
 
Values are cast to numbers by casting to strings and then casting the strings to numbers. These processes can be modified by defining <code>toString</code> and <code>valueOf</code> functions on the [[#Object-orientation (prototype-based)|prototype]] for string and number casting respectively.
 
JavaScript has received criticism for the way it implements these conversions as the complexity of the rules can be mistaken for inconsistency.<ref>{{cite web |date=2012 |title=Wat |url=https://www.destroyallsoftware.com/talks/wat |url-status=live |archive-url=https://web.archive.org/web/20191028204723/https://www.destroyallsoftware.com/talks/wat |archive-date=October 28, 2019 |access-date=October 28, 2019 |website=Destroy All Software |first1=Gary |last1=Bernhardt }}</ref><ref name="casting_rules" /> For example, when adding a number to a string, the number will be cast to a string before performing concatenation, but when subtracting a number from a string, the string is cast to a number before performing subtraction.
 
<center>
{| class="wikitable"
|+JavaScript type conversions
!left operand
!operator
!right operand
!result
|-
|<code>[]</code> (empty array)
! style="width:15%; text-align:left;"| Move left
|<code>+</code>
| style="width:85%; text-align:left;"| [To Fate I sue, of other means bereft, the only refuge for the wretched left.
|<code>[]</code> (empty array)
|<code>""</code> (empty string)
|-
|<code>[]</code> (empty array)
! style="width:15%; text-align:left;"| Center
|<code>+</code>
| style="width:85%; text-align:left;"| ]Paradise Lost[
|<code>{}</code> (empty object)
|<code>"[object Object]"</code> (string)
|-
|<code>false</code> (boolean)
! style="width:15%; text-align:left;"| Move up
|<code>+</code>
| style="width:85%; text-align:left;"| [[File:Quote to be Moved Up.svg|330px]]
|<code>[]</code> (empty array)
|<code>"false"</code> (string)
|-
|<code>"123"</code>(string)
|<code>+</code>
|<code>1</code> (number)
|<code>"1231"</code> (string)
|-
|<code>"123"</code> (string)
|<code>-</code>
|<code>1</code> (number)
|<code>122</code> (number)
|-
|<code>"123"</code> (string)
|<code>-</code>
|<code>"abc"</code> (string)
|<code>[[NaN]]</code> (number)
|}
</center>
 
Often also mentioned is <code>{} + []</code> resulting in <code>0</code> (number). This is misleading: the <code>{}</code> is interpreted as an empty code block instead of an empty object, and the empty array is cast to a number by the remaining unary <code>+</code> operator. If the expression is wrapped in parentheses - <code>({} + [])</code> – the curly brackets are interpreted as an empty object and the result of the expression is <code>"[object Object]"</code> as expected.<ref name="casting_rules" />
====Usage in scientific fields====
Brackets are used in [[mathematics]] in a variety of notations, including standard notations for [[interval (mathematics)|interval]]s, [[commutator]]s, the [[Floor and ceiling functions|floor function]], the [[Lie bracket of vector fields|Lie bracket]], [[Equivalence class#Notation and formal definition|equivalence classes]], the [[Iverson bracket]], and [[Matrix (mathematics)|matrices]]. Square brackets may also represent [[interval (mathematics)|interval]]s; ]0, 5[ for example, is the interval between 0 and 5, not including 0 or 5 (sometimes written (0,5)).
 
=== Dynamic ===
Brackets can also be used in [[chemistry]] to represent the [[concentration]] of a [[chemical substance]] or to denote distributed charge in a [[Complex (chemistry)|complex ion]].
{{Main|Dynamic programming}}
 
==== Typing ====
Brackets are used in many computer [[programming language]]s, primarily to force the order of evaluation and for parameter lists and [[array data structure|array]] indexing. But they are also used to denote general tuples, sets and other structures, just as in mathematics. There may be several other uses as well, depending on the language at hand.
{{Main|Dynamic typing}}
 
JavaScript is [[dynamic typing|dynamically typed]] like most other [[scripting language]]s. A [[type system|type]] is associated with a [[value (computer science)|value]] rather than an expression. For example, a [[Variable (programming)|variable]] initially bound to a number may be reassigned to a [[string (computer science)|string]].<ref>{{cite web|url=https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures|title=JavaScript data types and data structures |date=February 16, 2017|website=MDN |access-date=February 24, 2017|archive-date=March 14, 2017|archive-url=https://web.archive.org/web/20170314230542/https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures|url-status=live}}</ref> JavaScript supports various ways to test the type of objects, including [[duck typing]].{{Sfn|Flanagan|2006|pp=176–178}}
====Other uses====
In linguistics, [[phonetic transcription]]s are generally enclosed within brackets,<ref>''The Chicago Manual of Style, 15th ed.'', The University of Chicago Press, 2003, §6.107</ref> often using the [[International Phonetic Alphabet]], whereas [[phoneme|phonemic]] transcriptions typically use paired [[Slash (punctuation)|slash]]es. Pipes (| |) are often used to indicate a [[Morphophoneme|morphophonemic]] rather than phonemic representation. Other conventions are double slashes (// //), double pipes (|| ||) and curly brackets ({ }). In [[lexicography]], square brackets usually surround the section of a dictionary entry which contains the [[etymology]] of the word the entry defines.
 
==== Run-time evaluation ====
Brackets are used to denote parts of the text that need to be checked when preparing drafts prior to finalizing a document. They often denote points that have not yet been agreed to in legal drafts and the year in which a report was made for certain [[case law]] decisions.
{{Main|eval}}
JavaScript includes an <code>[[eval]]</code> function that can execute statements provided as strings at run-time.
 
=== Object-orientation (prototype-based) ===
=== Curly brackets {{anchor|Braces|Curly bracket}} ===
Prototypal inheritance in JavaScript is described by [[Douglas Crockford]] as:
{{Wiktionary|curly bracket}}
{{Blockquote
|You make prototype objects, and then ... make new instances. Objects are mutable in JavaScript, so we can augment the new instances, giving them new fields and methods. These can then act as prototypes for even newer objects. We don't need classes to make lots of similar objects... Objects inherit from objects. What could be more object oriented than that?<ref>{{cite web|last=Crockford|first=Douglas|title=Prototypal Inheritance in JavaScript|url=https://javascript.crockford.com/prototypal.html|access-date=20 August 2013|archive-date=13 August 2013|archive-url=https://web.archive.org/web/20130813163035/https://javascript.crockford.com/prototypal.html|url-status=live}}</ref>
}}
 
In JavaScript, an [[Object (computer science)|object]] is an [[associative array]], augmented with a prototype (see below); each key provides the name for an object [[Property (programming)|property]], and there are two syntactical ways to specify such a name: dot notation (<code>obj.x = 10</code>) and bracket notation (<code>obj["x"] = 10</code>). A property may be added, rebound, or deleted at run-time. Most [[property (programming)|properties]] of an object (and any property that belongs to an object's prototype inheritance chain) can be enumerated using a <code>for...in</code> loop.
Curly brackets { and } are also called '''braces''' in the United States (or, colloquially, '''squiggly brackets'''). They are rarely used in prose and have no widely accepted use in formal writing, but may be used to mark words or that should be taken as a group, to avoid confusion when other types of brackets are already in use, or for a special purpose specific to the publication (such as in a dictionary).<ref>[https://english.stackexchange.com/questions/127892/are-curly-braces-ever-used-in-normal-text-if-not-why-were-they-created Are curly braces ever used in normal text? If not, why were they created?]</ref> More commonly, they are used to indicate a group of lines that should be taken together, as in when referring to several lines of poetry that should be repeated.
 
==== Prototypes ====
In music, they are known as [[accolade (notation)|accolade]]s or "[[brace (music)|braces]]", and connect two or more lines ([[Staff (music)|stave]]s) of music that are played simultaneously.<ref>[https://web.archive.org/web/20081202121802/http://www.decodeunicode.org/u%2B007B Decodeunicode.org > U+007B LEFT CURLY BRACKET] Retrieved on 3 May 2009</ref>
{{Main|Prototype-based programming}}
 
JavaScript uses [[prototype-based programming|prototypes]] where many other object-oriented languages use [[Class (computer science)|classes]] for [[Inheritance (object-oriented programming)|inheritance]],<ref>{{cite web|title=Inheritance and the prototype chain|url=https://developer.mozilla.org/en-US/docs/JavaScript/Guide/Inheritance_and_the_prototype_chain|work=[[Mozilla]] Developer Network |access-date=April 6, 2013|archive-date=April 25, 2013|archive-url=https://web.archive.org/web/20130425144207/https://developer.mozilla.org/en-US/docs/JavaScript/Guide/Inheritance_and_the_prototype_chain|url-status=live}}</ref> but it's still possible to simulate most class-based features with the prototype system.<ref>{{cite book|last=Herman|first=David|title=Effective JavaScript|year=2013|publisher=Addison-Wesley|isbn=978-0-321-81218-6|page=83 |url=https://books.google.com/books?id=Nz9iAwAAQBAJ&pg=PA83 }}</ref> Additionally, [[ECMAScript |ECMAScript version 6]] (released June 2015) introduced the keywords '''class''', '''extends''' and '''super''', which serve as syntactic sugar to abstract the underlying prototypal inheritance system with a more conventional interface. Constructors are declared by specifying a method named '''constructor''', and all classes are automatically subclasses of the base class Object, similarly to Java. <syntaxhighlight lang="javascript">
In [[mathematics]] they delimit [[Set (mathematics)|set]]s, and in writing, they may be used similarly, "Select your animal {goat, sheep, cow, horse} and follow me". In many programming languages, they enclose groups of [[Statement (programming)|statement]]s. Such languages ([[C (programming language)|C]] being one of the best-known examples) are therefore called [[curly bracket language]]s.<ref>{{cite web|url=http://www.riedquat.de/prog/style |title=Brace and Indent Styles and Code Convention |work=riedquat.de |deadurl=yes |archiveurl=https://web.archive.org/web/20150924070732/http://www.riedquat.de/prog/style |archivedate=24 September 2015 |df= }}</ref> In [[classical mechanics]], curly brackets are often also used to denote the [[Poisson bracket]] between two quantities.
class Person {
constructor(name) {
this.name = name;
}
}
 
class Student extends Person {
=== Angle brackets {{anchor|Chevrons}} ===
constructor(name, id) {
{{refimprove section|date=November 2012}}
super(name);
{{redirect|Angle bracket|a device used for joining|Angle bracket (fastener)}}
this.id = id;
{{Wiktionary|angle bracket|chevron}}
}
}
 
const bob = new Student("Robert", 12345);
[[Wikt:chevron|Chevrons]] {{angbr|&nbsp;}}, similar to the commonly used [[less-than symbol|less-than]] (<) and [[greater-than symbol]] (>), are often used to enclose highlighted material.
console.log(bob.name); // Robert
</syntaxhighlight>Though the underlying object mechanism is still based on prototypes, the newer syntax is similar to other object oriented languages. Private variables are declared by prefixing the field name with a [[number sign]] (#), and [[Polymorphism (computer science)|polymorphism]] is not directly supported, although it can be emulated by manually calling different functions depending on the number and type of arguments provided.<ref name="JavaScriptNext">{{cite book |last=Ghandi |first=Raju |date=2019 |title=JavaScript Next|___location=New York City |publisher=Apress Media |pages=159–171 |isbn=978-1-4842-5394-6}}</ref>
 
==== Functions as object constructors ====
In physical sciences, chevrons are used to denote an average over time or over another continuous parameter. For example,
Functions double as object constructors, along with their typical role. Prefixing a function call with ''new'' will create an instance of a prototype, inheriting properties and methods from the constructor (including properties from the <code>Object</code> prototype).<ref name="Haverbeke2024">{{Cite book |title=Eloquent JavaScript |last=Haverbeke |first=Marijn |publisher=[[No Starch Press]] |isbn=978-1-71850-411-0 |edition=4th |___location=San Francisco |publication-date=September 2024 |pages=[https://eloquentjavascript.net/Eloquent_JavaScript.pdf#section*.204 97–98] |language=en |url=https://eloquentjavascript.net/Eloquent_JavaScript.pdf |archive-url=https://web.archive.org/web/20250312193854/https://eloquentjavascript.net/Eloquent_JavaScript.pdf |archive-date=2025-03-12 |url-status=live}}</ref> ECMAScript 5 offers the <code>Object.create</code> method, allowing explicit creation of an instance without automatically inheriting from the <code>Object</code> prototype (older environments can assign the prototype to <code>null</code>).<ref>{{cite web|last=Katz|first=Yehuda|title=Understanding "Prototypes" in JavaScript|date=12 August 2011|url=https://yehudakatz.com/2011/08/12/understanding-prototypes-in-javascript/|access-date=April 6, 2013|archive-date=5 April 2013|archive-url=https://web.archive.org/web/20130405154842/https://yehudakatz.com/2011/08/12/understanding-prototypes-in-javascript/|url-status=live}}</ref> The constructor's <code>prototype</code> property determines the object used for the new object's internal prototype. New methods can be added by modifying the prototype of the function used as a constructor.<syntaxhighlight lang="javascript">// This code is completely equivalent to the previous snippet
function Person(name) {
this.name = name;
}
 
function Student(name, id) {
:<math>\left\langle V(t)^2 \right\rangle = \lim_{T\to\infty} \frac{1}{T}\int_{-\frac{T}{2}}^{\frac{T}{2}} V(t)^2\,{\rm{d}}t. </math>
Person.call(this, name);
this.id = id;
}
 
var bob = new Student("Robert", 12345);
The [[inner product]] of two vectors is commonly written as {{math|{{angbr|''a'',''b''}}}}, but the notation {{math|(''a'',''b'')}} is also used.
console.log(bob.name); // Robert</syntaxhighlight>JavaScript's built-in classes, such as <code>Array</code> and <code>Object</code>, also have prototypes that can be modified. However, it's generally considered bad practice to [[Monkey patch|modify built-in objects]], because third-party code may use or inherit methods and properties from these objects, and may not expect the prototype to be modified.<ref>{{cite book |last=Herman |first=David |url=https://books.google.com/books?id=Nz9iAwAAQBAJ&pg=PA125 |title=Effective JavaScript |publisher=Addison-Wesley |year=2013 |isbn=978-0-321-81218-6 |pages=125–127}}</ref>
 
==== Functions as methods ====
In mathematical physics, especially [[quantum mechanics]], it is common to write the inner product between elements as {{math|{{bra-ket|''a''|''b''}}}}, as a short version of {{math|{{bra|''a''}}·{{ket|''b''}}}}, or {{math|{{bra|''a''}}''Ô''{{ket|''b''}}}}, where {{math|''Ô''}} is an [[Operator (physics)|operator]]. This is known as [[Dirac notation]] or [[bra–ket notation]].
{{Main|Method (computer science)}}
<!--not sure where to classify this under-->
 
Unlike in many object-oriented languages, in JavaScript there is no distinction between a function definition and a [[method (computer science)|method]] definition. Rather, the distinction occurs during function calling. When a function is called as a method of an object, the function's local ''this'' keyword is bound to that object for that invocation.
In [[set theory]], chevrons or parentheses are used to denote [[ordered pair]]s and other [[tuple]]s, whereas curly brackets are used for unordered sets.
 
=== Functional ===
In [[linguistics]], chevrons indicate [[grapheme]]s (i.e., written letters) or [[orthography]], as in "The English word {{IPA|/kæt/}} is spelled {{angbr|cat}}."<ref>{{cite book|last1=Bauer|first1=Laurie|title=The Linguistics Student's Handbook|date=2007|publisher=Edinburgh University Press|___location=Edinburgh|page=99|chapter-url=https://books.google.com/books?id=WsrtrmHkLvoC&pg=PA99|chapter=Notational conventions. Brackets}}</ref><ref name="Sampson">{{cite book|last1=Sampson|first1=Geoffrey|editor1-last=Allan|editor1-first=Keith|title=The Routledge Handbook of Linguistics|date=2016|publisher=Routledge|page=60|chapter-url=https://books.google.com/books?id=3vssCgAAQBAJ&pg=PA60|chapter=Writing systems: methods for recording language}}</ref><ref name="Trask"/>
{{Main|Functional programming}}
 
JavaScript [[Subroutine|functions]] are [[first-class function|first-class]]; a function is considered to be an object.<ref>{{cite web|title=Function&nbsp;– JavaScript|url=https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function|access-date=2021-10-30|website=[[MDN Web Docs]]|language=en-US}}</ref> As such, a function may have properties and methods, such as <code>.call()</code> and <code>.bind()</code>.<ref>{{cite web | url=https://es5.github.com/#x15.3.4-toc | title=Properties of the Function Object | publisher=Es5.github.com | access-date=May 26, 2013 | archive-date=January 28, 2013 | archive-url=https://web.archive.org/web/20130128185825/https://es5.github.com/#x15.3.4-toc | url-status=live }}</ref>
In [[epigraphy]], they may be used for mechanical transliterations of a text into the Latin script.<ref name="Sampson"/>
 
==== Lexical closure ====
In [[textual criticism]], and hence in many editions of pre-modern works, chevrons denote sections of the text which are illegible or otherwise lost; the editor will often insert their own reconstruction where possible within them.<ref name="Trask">{{cite book|last1=Trask|first1=Robert Lawrence|title=The Dictionary of Historical and Comparative Linguistics|date=2000|publisher=Edinburgh University Press|___location=Edinburgh|page=22|chapter-url=https://books.google.com/books?id=EHeGzQ8wuLQC&pg=PA22|chapter=Angle brackets}}</ref>
{{Main|Closure (computer programming)}}
 
A ''nested'' function is a function defined within another function. It is created each time the outer function is invoked.
Chevrons are infrequently used to denote words that are thought instead of spoken, such as:
:{{angbr| What an unusual flower! }}
 
In addition, each nested function forms a [[Closure (computer programming)|lexical closure]]: the [[Scope (programming)#Lexical scoping vs. dynamic scoping|lexical scope]] of the outer function (including any constant, local variable, or argument value) becomes part of the internal state of each inner function object, even after execution of the outer function concludes.{{Sfn|Flanagan|2006|p=141}}
The mathematical or logical symbols for ''greater-than'' (&gt;) and ''less-than'' (&lt;) are [[inequality (mathematics)|inequality]] symbols; when either symbol is bisected by a vertical line, it represents "not greater than" or "not less than," respectively. These [[symbol]]s are not punctuation marks when used, as intended, to represent an inequality. However, as true chevrons are not present on [[keyboard (computing)|computer keyboards]], the available less-than and greater-than symbols are often used instead. They are loosely referred to as ''angle[d] brackets'' or ''chevrons'' in this case, but more properly — and less confusingly — as ''pointy brackets'' (see the [[#Names for various bracket symbols|Names]] section above).{{citation needed|date=November 2012}}
 
==== Anonymous function ====
Single and double pairs of comparison operators (&lt;&lt;,&nbsp;&gt;&gt;) (meaning ''much smaller than'' and ''much greater than'') are sometimes used as a fallback instead of [[guillemet]]s («, ») (used as [[non-English usage of quotation marks|quotation marks in many languages]]) when the proper characters are not available on the [[computer keyboard|keyboard]] nor in the [[input method editor|input editor]].
{{Main|Anonymous function}}
 
JavaScript also supports [[anonymous function]]s.
In [[comic book]]s, chevrons are often used to mark dialogue that has been translated notionally from another language; in other words, if a character is speaking another language, instead of writing in the other language and providing a translation, one writes the translated text within chevrons. Of course, since no foreign language is actually written, this is only ''notionally'' translated.{{Citation needed|date=March 2017}}
 
=== Delegative ===
Chevron-like symbols are part of standard [[Chinese language|Chinese]], and [[Korean language|Korean]] punctuation, where they generally enclose the titles of books: ︿ and ﹀ or ︽ and ︾ for traditional [[tategaki|vertical printing]], and 〈 and 〉 or 《 and 》 for [[yokogaki|horizontal]] printing. See also [[non-English usage of quotation marks]].
{{Main|Delegation (object-oriented programming)}}
JavaScript supports implicit and explicit [[Delegation (object-oriented programming)|delegation]].
 
==== Functions as roles (Traits and Mixins) ====
In [[continuum mechanics]], chevrons may be used as [[Macaulay brackets]].
{{Main|Role-oriented programming|Traits (computer science)|Mixin}}
 
JavaScript natively supports various function-based implementations of [[Role-oriented programming|Role]]<ref>[https://peterseliger.blogspot.de/2014/04/the-many-talents-of-javascript.html#the-many-talents-of-javascript-for-generalizing-role-oriented-programming-approaches-like-traits-and-mixins The many talents of JavaScript for generalizing Role-Oriented Programming approaches like Traits and Mixins] {{Webarchive|url=https://web.archive.org/web/20171005050713/https://peterseliger.blogspot.de/2014/04/the-many-talents-of-javascript.html#the-many-talents-of-javascript-for-generalizing-role-oriented-programming-approaches-like-traits-and-mixins |date=2017-10-05 }}, Peterseliger.blogspot.de, April 11, 2014.</ref> patterns like [[Traits (computer science)|Traits]]<ref>[https://soft.vub.ac.be/~tvcutsem/traitsjs/ Traits for JavaScript] {{Webarchive|url=https://web.archive.org/web/20140724052500/https://soft.vub.ac.be/~tvcutsem/traitsjs/ |date=2014-07-24 }}, 2010.</ref><ref>{{cite web |url=https://cocktailjs.github.io/ |title=Home &#124; CocktailJS |website=Cocktailjs.github.io |access-date=February 24, 2017 |archive-date=February 4, 2017 |archive-url=https://web.archive.org/web/20170204083608/https://cocktailjs.github.io/ |url-status=live }}</ref> and [[Mixin]]s.<ref>{{cite web |url-status=live |first1=Angus |last1=Croll |url=https://javascriptweblog.wordpress.com/2011/05/31/a-fresh-look-at-javascript-mixins/ |title=A fresh look at JavaScript Mixins |archive-url=https://web.archive.org/web/20200415004603/https://javascriptweblog.wordpress.com/2011/05/31/a-fresh-look-at-javascript-mixins/ |archive-date=2020-04-15 |date=May 31, 2011 |website= JavaScript, JavaScript… }}</ref> Such a function defines additional behavior by at least one method bound to the <code>this</code> keyword within its <code>function</code> body. A Role then has to be delegated explicitly via <code>call</code> or <code>apply</code> to objects that need to feature additional behavior that is not shared via the prototype chain.
In [[non-English usage of quotation marks#Chinese, Japanese and Korean quotation marks|East Asian punctuation]], angle brackets are used as quotation marks.
 
==== Object composition and inheritance ====
=== Lenticular brackets ===
Whereas explicit function-based delegation does cover [[Object composition|composition]] in JavaScript, implicit delegation already happens every time the prototype chain is walked in order to, e.g., find a method that might be related to but is not directly owned by an object. Once the method is found it gets called within this object's context. Thus [[Inheritance (object-oriented programming)|inheritance]] in JavaScript is covered by a delegation automatism that is bound to the prototype property of constructor functions.
{{Wiktionary|【 】}}
 
=== Miscellaneous ===
Some [[East Asia|East Asian]] languages use lenticular brackets 【 】, a combination of square brackets and parentheses called {{lang|zh|方頭括號}} ''fāngtóu kuòhào'' in [[Chinese language|Chinese]] and {{lang|ja|
==== Zero-based numbering ====
すみ付き}} ''sumitsuki'' in [[Japanese language|Japanese]]. They are used for inference{{clarification needed|date=April 2017}} in Chinese and used in titles and headings in Japanese.
JavaScript is a [[Zero-based numbering#Usage in programming languages|zero-index]] language.
 
==== FloorVariadic and ceiling cornersfunctions ====
{{Main|Variadic function}}
{{Wiktionary|⌊ ⌋|⌈ ⌉}}
The floor corner brackets ⌊ and ⌋, the ceiling corner brackets ⌈ and ⌉ are used to denote the integer [[floor and ceiling functions]].
 
<!--note: this is not a functional programming feature-->
=== Quine corners and half brackets ===
An indefinite number of parameters can be passed to a function. The function can access them through [[formal parameter]]s and also through the local <code>arguments</code> object. [[Variadic functions]] can also be created by using the <code>[https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/bind bind]</code> method.
 
==== Array and object literals ====
The Quine corners ⌜ and ⌝ have at least two uses in [[mathematical logic]]: either as [[quasi-quotation]], a generalization of quotation marks, or to denote the [[Gödel numbering|Gödel number]] of the enclosed [[Expression (mathematics)|expression]].
{{Main|Associative arrays|Object literal}}
 
Like in many scripting languages, arrays and objects ([[associative arrays]] in other languages) can each be created with a succinct shortcut syntax. In fact, these [[Object literal|literals]] form the basis of the [[JSON]] data format.
Half brackets are used in English to mark added text, such as in translations: "Bill saw ⸤her⸥".
 
==== Regular expressions ====
In editions of [[papyrology|papyrological]] texts, half brackets, ⸤ and ⸥ or ⸢ and ⸣, enclose text which is lacking in the papyrus due to damage, but can be restored by virtue of another source, such as an ancient quotation of the text transmitted by the papyrus.<ref>M.L. West (1973) ''Textual Criticism and Editorial Technique'' (Stuttgart) 81.</ref> For example, [[Callimachus]] ''Iambus'' 1.2 reads: ἐκ τῶν ὅκου βοῦν κολλύ⸤βου π⸥ιπρήσκουσιν. A hole in the papyrus has obliterated βου π, but these letters are supplied by an ancient commentary on the poem. Second intermittent sources can be between ⸢ and ⸣. Quine corners are sometimes used instead of half brackets.<ref name="Unicode Miscellaneous Technical"/>
{{Main|Regular expression}}
 
JavaScript supports [[regular expression]]s for text searches and manipulation.{{r|n=Haverbeke2024|p=139}}
=== Double brackets ===
 
===== Promises =====
Double brackets (or white square brackets), ⟦&nbsp;⟧, are used to indicate the ''semantic evaluation function'' in [[formal semantics (linguistics)|formal semantics]] for natural language and [[denotational semantics]] for programming languages.<ref>Dowty, D., Wall, R. and Peters, S.: 1981, Introduction to Montague semantics, Springer.</ref><ref>Scott, D. and Strachey, C.: 1971, Toward a mathematical semantics for computer languages, Oxford
{{Main|Futures and promises}}
University Computing Laboratory, Programming Research Group.</ref> The brackets stand for a function that maps a linguistic expression to its “denotation” or semantic value. Double brackets may also refer to the mathematical [[Floor_and_ceiling_functions|floor function]].
 
A built-in Promise object provides functionality for handling promises and associating handlers with an asynchronous action's eventual result. JavaScript supplies combinator methods, which allow developers to combine multiple JavaScript promises and do operations based on different scenarios. The methods introduced are: Promise.race, Promise.all, Promise.allSettled and Promise.any.
=== Brackets with quills ===
 
===== Async/await =====
Known as "spike parentheses" ({{lang-sv|piggparenteser}}) ⁅ and ⁆ are used in Swedish dictionaries.<ref>See [[:sv:Parentes]]</ref>
{{Main|Async/await}}
 
Async/await allows an asynchronous, non-blocking function to be structured in a way similar to an ordinary synchronous function. Asynchronous, non-blocking code can be written, with minimal overhead, structured similarly to traditional synchronous, blocking code.
==Specific uses==
 
=== Vendor-specific extensions ===
===Computing===
Historically, some [[JavaScript engine]]s supported these non-standard features:
* [[List comprehension|array comprehensions]] and generator expressions (like Python)
* concise function expressions (<code>function(args) expr</code>; this experimental syntax predated arrow functions)
* [[ECMAScript for XML]] (E4X), an extension that adds native XML support to ECMAScript (unsupported in Firefox since version 21<ref>{{cite web|title=E4X – Archive of obsolete content |url=https://developer.mozilla.org/en-US/docs/Archive/Web/E4X|website=Mozilla Developer Network|publisher=Mozilla Foundation|date=February 14, 2014|access-date=July 13, 2014|archive-date=July 24, 2014|archive-url=https://web.archive.org/web/20140724100129/https://developer.mozilla.org/en-US/docs/Archive/Web/E4X|url-status=dead}}</ref>)
 
== Syntax ==
The various bracket characters are frequently used in many [[Programming language|programming languages]] as [[operator (computer programming)|operator]]s or for other [[syntax (programming languages)|syntax]] markup. For instance, in [[C (programming language)|C]]-like languages, <code>{</code> and <code>}</code> are often used to delimit a [[code block]], and the parameters of [[method call]]s are generally enclosed by <code>(</code> and <code>)</code>.
{{Main|JavaScript syntax}}
[[Variable (computer science)|Variables]] in JavaScript can be defined using either the <code>var</code>,<ref>{{cite web | url=https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Statements/var | title=var – JavaScript | publisher=The [[Mozilla Developer Network]] | access-date=December 22, 2012 | archive-date=December 23, 2012 | archive-url=https://web.archive.org/web/20121223162713/https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Statements/var | url-status=live }}</ref> <code>let</code><ref name="moz_let">{{cite web |title=let |url=https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/let |website=MDN web docs |publisher=Mozilla |access-date=June 27, 2018 |ref=moz_let |archive-date=May 28, 2019 |archive-url=https://web.archive.org/web/20190528140803/https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/let |url-status=live }}</ref> or <code>const</code><ref name="moz_const">{{cite web |title=const |url=https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/const |website=MDN web docs |publisher=Mozilla |access-date=June 27, 2018 |ref=moz_const |archive-date=June 28, 2018 |archive-url=https://web.archive.org/web/20180628044054/https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/const |url-status=live }}</ref> keywords. Variables defined without keywords will be defined at the global scope.
 
Arrow functions were first introduced in [[w:ECMAScript#6th Edition – ECMAScript 2015|6th Edition – ECMAScript 2015]]. They shorten the syntax for writing functions in JavaScript. Arrow functions are anonymous, so a variable is needed to refer to them in order to invoke them after their creation, unless surrounded by parenthesis and executed immediately.
In C, [[C++]], [[Java (programming language)|Java]] and other C-derived languages—as well as in [[Scheme (programming language)|Scheme]]-influenced languages that have adopted C/Java syntax, such as [[JavaScript]]—the "<code>{}</code>" symbols are referred to as "braces" or "curly braces" and never as brackets. Since the term "brace" is documented in the definitive programming specifications for these languages, it is preferable to use the correct term brace so there is no confusion between the brace (used to denote compound statements) and the bracket, used to denote other concepts, such as [[array data structure|array]] indices.<ref>Brian W. Kernighan, Dennis M. Ritchie. "The C Programming Language", 1988. p. 7. {{ISBN|0-13-110370-9}}</ref><ref>Bjarne Stroustrup, "The C++ Programming Language", 2013. p.39. {{ISBN|0-13-352285-7}}</ref>
 
Here is an example of JavaScript syntax.
===Mathematics===
<syntaxhighlight lang="javascript" start="1">
{{main|Bracket (mathematics)}}
// Declares a function-scoped variable named `x`, and implicitly assigns the
In addition to the use of [[#Parentheses ( )|parentheses]] to specify the [[order of operations]], both parentheses and brackets are used to denote an [[interval (mathematics)|interval]], also referred to as a half-open range. The notation {{closed-open|{{mvar|a}},{{mvar|c}}}} is used to indicate an interval from {{mvar|a}} to {{mvar|c}} that is inclusive of {{mvar|a}} but exclusive of {{mvar|c}}. That is, {{closed-open|5, 12}} would be the set of all real numbers between 5 and 12, including 5 but not 12. The numbers may come as close as they like to 12, including 11.999 and so forth (with any [[finite set|finite]] number of 9s), but 12.0 is not included. In some European countries, the notation {{math|[5, 12[}} is also used for this. The endpoint adjoining the bracket is known as ''closed'', whereas the endpoint adjoining the parenthesis is known as ''open''. If both types of brackets are the same, the entire interval may be referred to as ''closed'' or ''open'' as appropriate. Whenever [[Extended real number line|+∞]] or −∞ is used as an endpoint, it is normally considered ''open'' and adjoined to a parenthesis. See [[Interval (mathematics)]] for a more complete treatment.
// special value `undefined` to it. Variables without value are automatically
// set to undefined.
// var is generally considered bad practice and let and const are usually preferred.
var x;
 
// Variables can be manually set to `undefined` like so
In [[quantum mechanics]], chevrons are also used as part of [[Paul Dirac|Dirac's]] formalism, [[bra–ket notation]], to note vectors from the [[dual space]]s of the Bra&nbsp;{{angbr|{{math|''A''&#124;}} and the Ket&nbsp;{{math|&#124;''B''}}}}. Mathematicians will also commonly write {{angbr|{{math|''a'', ''b''}}}} for the [[inner product]] of two vectors. In statistical mechanics, chevrons denote ensemble or time average. Chevrons are used in [[group theory]] to write [[group presentation]]s, and to denote the [[group generators|subgroup generated]] by a collection of elements. Note that [[obtuse angle]]d chevrons are not always (and even not by all users) distinguished from a pair of less-than and greater-than signs &lt;&gt;, which are sometimes used as a [[typographic approximation]] of chevrons.
let x2 = undefined;
 
// Declares a block-scoped variable named `y`, and implicitly sets it to
In [[group theory]] and [[ring theory]], brackets denote the [[commutator]]. In group theory, the commutator {{math|[{{mvar|g}}, {{mvar|h}}]}} is commonly defined as {{math|{{mvar|g}}<sup> −1</sup> {{mvar|h}}<sup> −1</sup> {{mvar|g}} {{mvar|h}} }}. In ring theory, the commutator {{math|[{{mvar|a}}, {{mvar|b}}]}} is defined as {{math|{{mvar|a}} {{mvar|b}} − {{mvar|b}} {{mvar|a}} }}. Furthermore, in ring theory, braces denote the [[anticommutator]] where {{math|{{{mvar|a}}, {{mvar|b}}}}} is defined as {{math|{{mvar|a}} {{mvar|b}} + {{mvar|b}} {{mvar|a}} }}. The bracket is also used to denote the [[Lie derivative]], or more generally the Lie bracket in any [[Lie algebra]].
// `undefined`. The `let` keyword was introduced in ECMAScript 2015.
let y;
 
// Declares a block-scoped, un-reassignable variable named `z`, and sets it to
Various notations, like the [[vinculum (symbol)|vinculum]] have a similar effect to brackets in specifying order of operations, or otherwise grouping several characters together for a common purpose.
// a string literal. The `const` keyword was also introduced in ECMAScript 2015,
// and must be explicitly assigned to.
 
// The keyword `const` means constant, hence the variable cannot be reassigned
In the [[Z notation|Z]] [[formal specification]] language, braces define a set and chevrons define a sequence.
// as the value is `constant`.
const z = "this value cannot be reassigned!";
 
// Declares a global-scoped variable and assigns 3. This is generally considered
===Accounting===
// bad practice, and will not work if strict mode is on.
Traditionally in [[Accountancy|accounting]], contra amounts are placed in parentheses. A debit balance account in a series of credit balances will have brackets and vice versa.
t = 3;
 
// Declares a variable named `myNumber`, and assigns a number literal (the value
===Law===
// `2`) to it.
Brackets are used in some countries in the citation of [[law report]]s to identify parallel citations to non-official reporters. For example: Chronicle Pub. Co. v. [[Superior Court]], (1998) 54 Cal.2d 548, [7 Cal.Rptr. 109]. In some other countries (such as [[England and Wales]]), square brackets are used to indicate that the year is part of the citation and parentheses are used to indicate the year the judgment was given. For example, National Coal Board v England [1954] AC 403, is in the 1954 volume of the Appeal Cases reports although the decision may have been given in 1953 or earlier, whereas (1954) 98 Sol Jo 176 reports a decision from 1954, in volume 98 of the Solicitor's Journal which may be published in 1955 or later.
let myNumber = 2;
 
// Reassigns `myNumber`, setting it to a string literal (the value `"foo"`).
When quoted material is in any way altered, the alterations are enclosed in brackets within the quotation. For example: Plaintiff asserts his cause is just, stating, "[m]y causes is [[sic|{{bracket|''sic''}}]] just." Although in the original quoted sentence the word "my" was capitalized, it has been modified in the quotation and the change signalled with brackets. Similarly, where the quotation contained a grammatical error, the quoting author signalled that the error was in the original with "[''sic'']" (Latin for 'thus'). (''California Style Manual'', section 4:59 (4th ed.))
// JavaScript is a dynamically-typed language, so this is legal.
myNumber = "foo";
</syntaxhighlight>
 
Note the [[Comment (computer programming)|comments]] in the examples above, all of which were preceded with two [[Slash (punctuation)|forward slashes]].
===Sports===
[[Bracket (tournament)|Tournament brackets]], the diagrammatic representation of the series of games played during a tournament usually leading to a single winner, are so named for their resemblance to brackets or braces.
 
More examples can be found at the [[wikibooks:JavaScript/Syntax examples|Wikibooks page on JavaScript syntax examples]].
== {{anchor|Encoding}}Encoding in digital media ==
Representations of various kinds of brackets in [[Unicode]] and [[HTML]] are given below.
 
== Security ==
{|class="wikitable"
{{See also|Browser security}}
|-
JavaScript and the [[Document Object Model|DOM]] provide the potential for malicious authors to deliver scripts to run on a client computer via the Web. Browser authors minimize this risk using two restrictions. First, scripts run in a [[Sandbox (computer security)|sandbox]] in which they can only perform Web-related actions, not general-purpose programming tasks like creating files. Second, scripts are constrained by the [[same-origin policy]]: scripts from one website do not have access to information such as usernames, passwords, or cookies sent to another site. Most JavaScript-related security bugs are breaches of either the same origin policy or the sandbox.
!scope="col"| Usage !!colspan="2" scope="col"| Unicode !!scope="col"| SGML/[[List of HTML and XML character entities|HTML/XML entities]] !!scope="col"| Sample
 
|-
There are subsets of general JavaScript—ADsafe, Secure ECMAScript (SES)—that provide greater levels of security, especially on code created by third parties (such as advertisements).<ref>{{cite web | url=https://www.adsafe.org/ | title=Making JavaScript Safe for Advertising | publisher=ADsafe | access-date=2021-05-08 | archive-date=2021-07-06 | archive-url=https://web.archive.org/web/20210706153324/https://www.adsafe.org/ | url-status=live }}</ref><ref>{{cite web | url=https://code.google.com/p/es-lab/wiki/SecureEcmaScript | title=Secure ECMA Script (SES) | access-date=May 26, 2013 | archive-date=May 15, 2013 | archive-url=https://web.archive.org/web/20130515073412/https://code.google.com/p/es-lab/wiki/SecureEcmaScript | url-status=live }}</ref> Closure Toolkit is another project for safe embedding and isolation of third-party JavaScript and HTML.<ref>{{cite web|title=Google Caja Project|url=https://developers.google.com/caja/|url-status=live|website=[[Google]]|access-date=2021-07-09|archive-date=2021-01-22|archive-url=https://web.archive.org/web/20210122083321/https://developers.google.com/caja/}}</ref>
|rowspan="4"| General purpose<ref name="Basic Latin">{{citation | url=http://www.unicode.org/charts/PDF/U0000.pdf | title=C0 Controls and Basic Latin Code Chart | work=The Unicode Standard | accessdate=2016-02-27}}</ref>
 
| U+0028 || Left parenthesis || &amp;#40; &amp;lparen; ||rowspan="2"| (parentheses)
[[Content Security Policy]] is the main intended method of ensuring that only trusted code is executed on a Web page.
|-
 
| U+0029 || Right parenthesis || &amp;#41; &amp;rparen;
=== Cross-site scripting ===
|-
{{Main|Cross-site scripting}}
| U+005B || Left square bracket || &amp;#91; ||rowspan="2"| [''[[sic]]'']
 
|-
A common JavaScript-related security problem is [[cross-site scripting]] (XSS), a violation of the [[same-origin policy]]. XSS vulnerabilities occur when an attacker can cause a target Website, such as an online banking website, to include a malicious script in the webpage presented to a victim. The script in this example can then access the banking application with the privileges of the victim, potentially disclosing secret information or transferring money without the victim's authorization. One important solution to XSS vulnerabilities is [[HTML sanitization]].
| U+005D || Right square bracket || &amp;#93;
 
|-
Some browsers include partial protection against ''reflected'' XSS attacks, in which the attacker provides a URL including malicious script. However, even users of those browsers are vulnerable to other XSS attacks, such as those where the malicious code is stored in a database. Only correct design of Web applications on the server-side can fully prevent XSS.
|rowspan="4"| Technical/mathematical<br>(common)<ref name="Basic Latin"/>
 
| U+003C || Less-than sign || &amp;#60; &amp;lt; ||rowspan="2"| &lt;HTML&gt;
XSS vulnerabilities can also occur because of implementation mistakes by browser authors.<ref>{{cite web |url=https://www.mozillazine.org/talkback.html?article=4392 |title=Mozilla Cross-Site Scripting Vulnerability Reported and Fixed&nbsp;– MozillaZine Talkback |website=Mozillazine.org |access-date=February 24, 2017 |archive-date=July 21, 2011 |archive-url=https://web.archive.org/web/20110721230916/http://www.mozillazine.org/talkback.html?article=4392 |url-status=live }}</ref>
|-
 
| U+003E || Greater-than sign || &amp;#62; &amp;gt;
=== Cross-site request forgery ===
|-
{{Main|Cross-site request forgery}}
| U+007B || Left curly bracket || &amp;#123; ||rowspan="2"| {round, square, curly}
 
|-
Another cross-site vulnerability is [[cross-site request forgery]] (CSRF). In CSRF, code on an attacker's site tricks the victim's browser into taking actions the user did not intend at a target site (like transferring money at a bank). When target sites rely solely on cookies for request authentication, requests originating from code on the attacker's site can carry the same valid login credentials of the initiating user. In general, the solution to CSRF is to require an authentication value in a hidden form field, and not only in the cookies, to authenticate any request that might have lasting effects. Checking the HTTP Referrer header can also help.
| U+007D || Right curly bracket || &amp;#125;
 
|-
"JavaScript hijacking" is a type of CSRF attack in which a {{code|<script>}} tag on an attacker's site exploits a page on the victim's site that returns private information such as [[JSON]] or JavaScript. Possible solutions include:
<!-- not brackets, see ==List of types==-->
 
|rowspan="10"| Quotation<br>(Western texts)<ref name="Latin-1 Supplement">{{citation | url=http://www.unicode.org/charts/PDF/U0080.pdf | title=C1 Controls and Latin-1 Supplement Code Chart | work=The Unicode Standard | accessdate=2016-02-27}}</ref><ref name="General Punctuation"/>
* requiring an authentication token in the [[POST (HTTP)|POST]] and [[GET (HTTP)|GET]] parameters for any response that returns private information.
| U+00AB || Left-pointing double angle quotation mark || &amp;#171; ||rowspan="2"| «&thinsp;French quote&thinsp;»
 
|-
=== Misplaced trust in the client ===
| U+00BB || Right-pointing double angle quotation mark || &amp;#187;
Developers of client-server applications must recognize that untrusted clients may be under the control of attackers. The author of an application should not assume that their JavaScript code will run as intended (or at all) because any secret embedded in the code could be extracted by a determined adversary. Some implications are:
|-
* Website authors cannot perfectly conceal how their JavaScript operates because the raw source code must be sent to the client. The code can be [[obfuscated code|obfuscated]], but obfuscation can be reverse-engineered.
| U+2039|| Single left-pointing angle quotation mark || &amp;#8249; ||rowspan="2"| ‹&thinsp;''{{math|x}}''&thinsp;›
* JavaScript form validation only provides convenience for users, not security. If a site verifies that the user agreed to its terms of service, or filters invalid characters out of fields that should only contain numbers, it must do so on the server, not only the client.
|-
* Scripts can be selectively disabled, so JavaScript cannot be relied on to prevent operations such as right-clicking on an image to save it.<ref>{{cite web |last1=Kottelin |first1=Thor |title=Right-click "protection"? Forget about it |url=https://blog.anta.net/2008/06/17/right-click-%E2%80%9Cprotection%E2%80%9D-forget-about-it/ |website=blog.anta.net |access-date=28 July 2022 |archive-url=https://web.archive.org/web/20110809195359/https://blog.anta.net/2008/06/17/right-click-%E2%80%9Cprotection%E2%80%9D-forget-about-it/ |archive-date=9 August 2011 |date=17 June 2008}}</ref>
| U+203A || Single right-pointing angle quotation mark || &amp;#8250;
* It is considered very bad practice to embed sensitive information such as passwords in JavaScript because it can be extracted by an attacker.<ref>{{cite web |last1=Rehorik |first1=Jan |title=Why You Should Never Put Sensitive Data in Your JavaScript |url=https://www.serviceobjects.com/blog/why-you-should-never-put-sensitive-data-in-your-javascript/ |website=ServiceObjects Blog |date=29 November 2016 |publisher=ServiceObjects |access-date=June 3, 2019 |archive-date=June 3, 2019 |archive-url=https://web.archive.org/web/20190603142957/https://www.serviceobjects.com/blog/why-you-should-never-put-sensitive-data-in-your-javascript/ |url-status=live }}</ref>
|-
* [[Prototype pollution]] is a runtime vulnerability in which attackers can overwrite arbitrary properties in an object's prototype.
| U+201C || Left double quotation mark || &amp;#8220; ||rowspan="2"| “English quote”
 
|-
=== Misplaced trust in developers ===
| U+201D || Right double quotation mark || &amp;#8221;
Package management systems such as [[npm (software)|npm]] and Bower are popular with JavaScript developers. Such systems allow a developer to easily manage their program's dependencies upon other developers' program libraries. Developers trust that the maintainers of the libraries will keep them secure and up to date, but that is not always the case. A vulnerability has emerged because of this blind trust. Relied-upon libraries can have new releases that cause bugs or vulnerabilities to appear in all programs that rely upon the libraries. Inversely, a library can go unpatched with known vulnerabilities out in the wild. In a study done looking over a sample of 133,000 websites, researchers found 37% of the websites included a library with at least one known vulnerability.<ref name="jslibs">{{citation |last1=Lauinger |first1=Tobias |last2=Chaabane |first2=Abdelberi |last3=Arshad |first3=Sajjad |last4=Robertson |first4=William |last5=Wilson |first5=Christo |last6=Kirda |first6=Engin |title=Thou Shalt Not Depend on Me: Analysing the Use of Outdated JavaScript Libraries on the Web |url=https://www.ccs.neu.edu/home/arshad/publications/ndss2017jslibs.pdf |website=Northeastern University |access-date=28 July 2022 |archive-url=https://web.archive.org/web/20170329045344/https://www.ccs.neu.edu/home/arshad/publications/ndss2017jslibs.pdf |archive-date=29 March 2017 |doi = 10.14722/ndss.2017.23414 |date = December 21, 2016|arxiv=1811.00918 |isbn=978-1-891562-46-4 |s2cid=17885720 |url-status=dead}}</ref> "The median lag between the oldest library version used on each website and the newest available version of that library is 1,177 days in ALEXA, and development of some libraries still in active use ceased years ago."<ref name="jslibs" /> Another possibility is that the maintainer of a library may remove the library entirely. This occurred in March 2016 when Azer Koçulu removed his repository from npm. This caused tens of thousands of programs and websites depending upon his libraries to break.<ref>{{cite news |work=Quartz |url=https://qz.com/646467/how-one-programmer-broke-the-internet-by-deleting-a-tiny-piece-of-code/ |title=How one programmer broke the internet by deleting a tiny piece of code |first=Keith |last=Collins |date=March 27, 2016 |access-date=February 22, 2017 |archive-date=February 22, 2017 |archive-url=https://web.archive.org/web/20170222200836/https://qz.com/646467/how-one-programmer-broke-the-internet-by-deleting-a-tiny-piece-of-code/ |url-status=live }}</ref><ref>SC Magazine UK, [https://www.scmagazineuk.com/developers-11-lines-of-deleted-code-breaks-the-internet/article/532050/ Developer's 11 lines of deleted code 'breaks the internet'] {{Webarchive|url=https://web.archive.org/web/20170223041434/https://www.scmagazineuk.com/developers-11-lines-of-deleted-code-breaks-the-internet/article/532050/ |date=February 23, 2017 }}</ref>
|-
 
| U+2018 || Left single quotation mark || &amp;#8216; ||rowspan="2"| ‘English quote’
=== Browser and plugin coding errors ===
|-
{{Further|Buffer overflow}}
| U+2019 || Right single quotation mark || &amp;#8217;
JavaScript provides an interface to a wide range of browser capabilities, some of which may have flaws such as [[buffer overflow]]s. These flaws can allow attackers to write scripts that would run any code they wish on the user's system. This code is not by any means limited to another JavaScript application. For example, a buffer overrun exploit can allow an attacker to gain access to the operating system's [[API]] with superuser privileges.
|-
 
| U+201A || Single low-9 quotation mark || &amp;#8218; &amp;sbquo; || ‚German quote‘ or ‚Polish quote’
These flaws have affected major browsers including Firefox,<ref>Mozilla Corporation, [https://www.mozilla.org/security/announce/2006/mfsa2006-38.html Buffer overflow in crypto.signText()] {{Webarchive|url=https://web.archive.org/web/20140604014705/https://www.mozilla.org/security/announce/2006/mfsa2006-38.html |date=2014-06-04 }}</ref> Internet Explorer,<ref>{{cite web|last1=Festa |first1=Paul |title=Buffer-overflow bug in IE |url=https://news.com.com/2100-1001-214620.html |archive-url=https://web.archive.org/web/20021225190522/https://news.com.com/2100-1001-214620.html |url-status=dead |archive-date=December 25, 2002 |website=[[CNET]] |date=August 19, 1998 }}</ref> and Safari.<ref>SecurityTracker.com, [https://securitytracker.com/alerts/2006/Mar/1015713.html Apple Safari JavaScript Buffer Overflow Lets Remote Users Execute Arbitrary Code and HTTP Redirect Bug Lets Remote Users Access Files] {{Webarchive|url=https://web.archive.org/web/20100218102849/https://securitytracker.com/alerts/2006/Mar/1015713.html |date=2010-02-18 }}</ref>
|-
 
| U+201E || Double low-9 quotation mark || &amp;#8222; &amp;bdquo; || „German quote“ or „Polish quote”
Plugins, such as video players, [[Adobe Flash#Flash client security|Adobe Flash]], and the wide range of [[ActiveX]] controls enabled by default in Microsoft Internet Explorer, may also have flaws exploitable via JavaScript (such flaws have been exploited in the past).<ref>SecurityFocus, [https://www.securityfocus.com/bid/19030/info Microsoft WebViewFolderIcon ActiveX Control Buffer Overflow Vulnerability] {{Webarchive|url=https://web.archive.org/web/20111011091819/http://www.securityfocus.com/bid/19030/info |date=2011-10-11 }}</ref><ref>Fusion Authority, [https://www.fusionauthority.com/security/3234-macromedia-flash-activex-buffer-overflow.htm Macromedia Flash ActiveX Buffer Overflow] {{webarchive|url=https://web.archive.org/web/20110813160055/https://www.fusionauthority.com/security/3234-macromedia-flash-activex-buffer-overflow.htm |date=August 13, 2011 }}</ref>
|-
 
|rowspan="4"| [[Floor and ceiling functions]]<ref name="Unicode Miscellaneous Technical">{{citation | url=http://www.unicode.org/charts/PDF/U2300.pdf | title=Miscellaneous Technical Code Chart | work=The Unicode Standard | accessdate=2016-02-27}}</ref>
In Windows Vista, Microsoft has attempted to contain the risks of bugs such as buffer overflows by running the Internet Explorer process with limited privileges.<ref>{{cite web |url=https://blogs.msdn.com/ie/archive/2006/02/09/528963.aspx |title=Protected Mode in Vista IE7 – IEBlog |website=Blogs.msdn.com |date=February 9, 2006 |access-date=February 24, 2017 |archive-date=January 23, 2010 |archive-url=https://web.archive.org/web/20100123103719/https://blogs.msdn.com/ie/archive/2006/02/09/528963.aspx |url-status=live }}</ref> [[Google Chrome]] similarly confines its page renderers to their own "[[Sandbox (computer security)|sandbox]]".
| U+2308 || Left ceiling || &amp;#8968; ||rowspan="2"| ⌈''ceiling''⌉
 
|-
=== Sandbox implementation errors ===
| U+2309 || Right ceiling || &amp;#8969;
Web browsers are capable of running JavaScript outside the sandbox, with the privileges necessary to, for example, create or delete files. Such privileges are not intended to be granted to code from the Web.
|-
 
| U+230A || Left floor || &amp;#8970; ||rowspan="2"| ⌊''floor''⌋
Incorrectly granting privileges to JavaScript from the Web has played a role in vulnerabilities in both Internet Explorer<ref>US CERT, [https://www.kb.cert.org/vuls/id/713878 Vulnerability Note VU#713878: Microsoft Internet Explorer does not properly validate source of redirected frame] {{Webarchive|url=https://web.archive.org/web/20091030051811/https://www.kb.cert.org/vuls/id/713878/ |date=2009-10-30 }}</ref> and Firefox.<ref>Mozilla Foundation, [https://www.mozilla.org/security/announce/2005/mfsa2005-41.html Mozilla Foundation Security Advisory 2005–41: Privilege escalation via DOM property overrides] {{Webarchive|url=https://web.archive.org/web/20140604014832/https://www.mozilla.org/security/announce/2005/mfsa2005-41.html |date=2014-06-04 }}</ref> In Windows XP Service Pack 2, Microsoft demoted JScript's privileges in Internet Explorer.<ref>{{cite web |last=Andersen |first=Starr |date=2004-08-09 |url=https://docs.microsoft.com/en-us/previous-versions/windows/it-pro/windows-xp/bb457150(v=technet.10) |title=Part 5: Enhanced Browsing Security |department=[[Microsoft TechNet|TechNet]] |website=[[Microsoft Docs]] |series=Changes to Functionality in Windows XP Service Pack 2 |access-date=2021-10-20}}</ref>
|-
 
| U+230B || Right floor || &amp;#8971;
[[Microsoft Windows]] allows JavaScript source files on a computer's hard drive to be launched as general-purpose, non-sandboxed programs (see: [[Windows Script Host]]). This makes JavaScript (like [[VBScript]]) a theoretically viable vector for a [[Trojan horse (computing)|Trojan horse]], although JavaScript Trojan horses are uncommon in practice.<ref>For one example of a rare JavaScript Trojan Horse, see Symantec Corporation, [https://www.symantec.com/security_response/writeup.jsp?docid=2003-100111-0931-99 JS.Seeker.K] {{Webarchive|url=https://web.archive.org/web/20110913210848/http://www.symantec.com/security_response/writeup.jsp?docid=2003-100111-0931-99 |date=2011-09-13 }}</ref>{{failed verification|date=March 2017}}
|-
 
|rowspan="4"| [[quasi-quotation|Quine corners]]<ref name="Unicode Miscellaneous Technical"/>
=== Hardware vulnerabilities ===
| U+231C || Top left corner || &amp;#8988; ||rowspan="2"| ⌜''quasi-quotation''⌝<br>⌜''editorial notation''⌝
In 2015, a JavaScript-based proof-of-concept implementation of a [[rowhammer]] attack was described in a paper by security researchers.<ref>{{cite arXiv | eprint = 1507.06955 | title = Rowhammer.js: A Remote Software-Induced Fault Attack in JavaScript | date = July 24, 2015 | last1 = Gruss | first1 = Daniel | last2 = Maurice | first2 = Clémentine | last3 = Mangard | first3 = Stefan | class = cs.CR }}</ref><ref>{{cite news |work=Motherboard |publisher=[[Vice (magazine)|Vice]] |title=Rowhammer.js Is the Most Ingenious Hack I've Ever Seen |first=Alix |last=Jean-Pharuns |date=July 30, 2015 |url=https://www.vice.com/en/article/rowhammerjs-is-the-most-ingenious-hack-ive-ever-seen/ |access-date=January 26, 2018 |archive-date=January 27, 2018 |archive-url=https://web.archive.org/web/20180127084042/https://motherboard.vice.com/en_us/article/9akpwz/rowhammerjs-is-the-most-ingenious-hack-ive-ever-seen |url-status=live }}</ref><ref>{{cite web|website=[[Ars Technica]]|title=DRAM 'Bitflipping' exploit for attacking PCs: Just add JavaScript|first=Dan|last=Goodin|date=August 4, 2015|url=https://arstechnica.com/information-technology/2015/08/dram-bitflipping-exploit-for-attacking-pcs-just-add-javascript/|access-date=January 26, 2018|archive-date=January 27, 2018|archive-url=https://web.archive.org/web/20180127143154/https://arstechnica.com/information-technology/2015/08/dram-bitflipping-exploit-for-attacking-pcs-just-add-javascript/|url-status=live}}</ref><ref>{{cite web | url = https://www.slate.com/articles/technology/bitwise/2015/07/rowhammer_security_exploit_why_a_new_security_attack_is_truly_terrifying.html | title = Rowhammer security exploit: Why a new security attack is truly terrifying | date = July 28, 2015 | access-date = July 29, 2015 | first = David | last = Auerbach | author-link = David Auerbach | website = slate.com | archive-date = July 30, 2015 | archive-url = https://web.archive.org/web/20150730004023/https://www.slate.com/articles/technology/bitwise/2015/07/rowhammer_security_exploit_why_a_new_security_attack_is_truly_terrifying.html | url-status = live }}</ref>
|-
 
| U+231D || Top right corner || &amp;#8989;
In 2017, a JavaScript-based attack via browser was demonstrated that could bypass [[Address space layout randomization|ASLR]]. It is called "ASLR⊕Cache" or AnC.<ref>[https://www.vusec.net/projects/anc/ AnC] {{Webarchive|url=https://web.archive.org/web/20170316055626/https://www.vusec.net/projects/anc/ |date=2017-03-16 }} VUSec, 2017</ref><ref>[https://arstechnica.com/security/2017/02/new-aslr-busting-javascript-is-about-to-make-drive-by-exploits-much-nastier/ New ASLR-busting JavaScript is about to make drive-by exploits much nastier] {{Webarchive|url=https://web.archive.org/web/20170316024419/https://arstechnica.com/security/2017/02/new-aslr-busting-javascript-is-about-to-make-drive-by-exploits-much-nastier/ |date=2017-03-16 }} Ars Technica, 2017</ref>
|-
 
| U+231E || Bottom left corner || &amp;#8990; ||rowspan="2"| ⌞''editorial notation''⌟
In 2018, the paper that announced the [[Spectre (security vulnerability)|Spectre]] attacks against Speculative Execution in Intel and other processors included a JavaScript implementation.<ref>[https://spectreattack.com/spectre.pdf Spectre Attack] {{Webarchive|url=https://web.archive.org/web/20180103225843/https://spectreattack.com/spectre.pdf |date=2018-01-03 }} Spectre Attack</ref>
|-
 
| U+231F || Bottom right corner || &amp;#8991;
== Development tools ==
|-
Important tools have evolved with the language.
|rowspan="79"| Technical/mathematical<br>(specialized)<ref name="Unicode Miscellaneous Technical" /><ref>{{citation | url=http://www.unicode.org/charts/PDF/U2070.pdf|title=Superscripts and Subscripts Code Chart|work=The Unicode Standard|accessdate=2016-02-27}}</ref><ref name="Unicode Miscellaneous Mathematical Symbols-A">{{citation | url=http://www.unicode.org/charts/PDF/U27C0.pdf | title=Miscellaneous Mathematical Symbols-A Code Chart | work=The Unicode Standard | accessdate=2016-02-27}}</ref><ref name="Unicode Miscellaneous Mathematical Symbols-B">{{citation | url=http://www.unicode.org/charts/PDF/U2980.pdf | title=Miscellaneous Mathematical Symbols-B Code Chart | work=The Unicode Standard | accessdate=2016-02-27}}</ref>
 
|-
* Every major web browser has built-in [[web development tools]], including a JavaScript [[debugger]].
| U+207D || Superscript left parenthesis || &amp;#8317; ||rowspan="2"| X⁽²⁾
* [[Static program analysis]] tools, such as [[ESLint]] and [[JSLint]], scan JavaScript code for conformance to a set of standards and guidelines.
|-
* Some browsers have built-in [[Profiling (computer programming)|profilers]]. Stand-alone profiling libraries have also been created, such as benchmark.js and jsbench.<ref>{{cite web|url=https://benchmarkjs.com/|title=Benchmark.js|website=benchmarkjs.com|access-date=2016-11-06|archive-date=2016-12-19|archive-url=https://web.archive.org/web/20161219182724/https://benchmarkjs.com/|url-status=live}}</ref><ref name="auto1">{{cite web|url=https://jsben.ch|title=JSBEN.CH Performance Benchmarking Playground for JavaScript|last=JSBEN.CH|website=jsben.ch|access-date=2021-08-13|archive-date=2021-02-27|archive-url=https://web.archive.org/web/20210227052409/https://jsben.ch/|url-status=live}}</ref>
| U+207E || Superscript right parenthesis || &amp;#8318;
* Many [[text editor]]s have syntax highlighting support for JavaScript code.
|-
 
| U+208D || Subscript left parenthesis || &amp;#8333; ||rowspan="2" | X₍₂₎
== Related technologies ==
|-
=== Java ===
| U+208E || Subscript right parenthesis || &amp;#8334;
A common misconception is that JavaScript is directly related to [[Java (programming language)|Java]].<!-- While one is intentionally similar to the other, they're different. (Previously the misconception sentence said "JavaScript is similar to Java" but that's not a misconception) --> Both indeed have a C-like syntax (the C language being their most immediate common ancestor language). They are also typically [[Sandbox (computer security)|sandboxed]], and JavaScript was designed with Java's syntax and standard library in mind. In particular, all Java keywords were reserved in original JavaScript, JavaScript's standard library follows Java's naming conventions, and JavaScript's {{code|lang=javascript|code=Math}} and {{code|lang=javascript|code=Date}} objects are based on classes from Java 1.0.<ref name="popularity">{{cite web | url=https://brendaneich.com/2008/04/popularity/ | title=Popularity | first=Brendan | last=Eich | author-link=Brendan Eich | date=April 3, 2008 | access-date=January 19, 2012 | archive-date=July 3, 2011 | archive-url=https://web.archive.org/web/20110703020955/https://brendaneich.com/2008/04/popularity/ | url-status=live }}</ref>
|-
 
| U+239B || Left parenthesis upper hook || &amp;#9115; ||rowspan="6"|
Both languages first appeared in 1995, but Java was developed by [[James Gosling]] of Sun Microsystems and JavaScript by [[Brendan Eich]] of Netscape Communications.
{|
 
| ⎛<br/>⎜<br/>⎝
The differences between the two languages are more prominent than their similarities. Java has [[static typing]], while JavaScript's typing is [[Dynamic typing|dynamic]]. Java is loaded from [[Compiler|compiled]] bytecode, while JavaScript is loaded as human-readable source code. Java's objects are [[Class-based programming|class-based]], while JavaScript's are [[Prototype-based programming|prototype-based]]. Finally, Java did not support functional programming until Java 8, while JavaScript has done so from the beginning, being influenced by [[Scheme (programming language)|Scheme]].
| large parentheses
 
|⎞<br/>⎟<br/>⎠
=== JSON ===
|}
[[JSON]] is a data format derived from JavaScript; hence the name JavaScript Object Notation. It is a widely used format supported by many other programming languages.
|-
 
| U+239C || Left parenthesis extension || &amp;#9116;
=== Transpilers ===
|-
Many websites are JavaScript-heavy, so [[transpiler]]s have been created to convert code written in other languages, which can aid the development process.<ref name="transpilers">{{cite web |title=List of languages that compile to JS |first=Jeremy |last=Ashkenas |website=[[GitHub]] |author-link=Jeremy Ashkenas |url=https://github.com/jashkenas/coffeescript/wiki/List-of-languages-that-compile-to-JS |access-date=February 6, 2020 |archive-date=January 31, 2020 |archive-url=https://web.archive.org/web/20200131233044/https://github.com/jashkenas/coffeescript/wiki/List-of-languages-that-compile-to-JS |url-status=live }}</ref>
| U+239D || Left parenthesis lower hook || &amp;#9117;
 
|-
[[TypeScript]] and [[CoffeeScript]] are two notable languages that transpile to JavaScript.
| U+239E || Right parenthesis upper hook || &amp;#9118;
|-
| U+239F || Right parenthesis extension || &amp;#9119;
|-
| U+23A0 || Right parenthesis lower hook || &amp;#9120;
|-
| U+23A1 || Left square bracket upper corner || &amp;#9121; ||rowspan="6"|
{|
| ⎡<br/>⎢<br/>⎣
| large square brackets
| ⎤<br/>⎥<br/>⎦
|}
|-
| U+23A2 || Left square bracket extension || &amp;#9122;
|-
| U+23A3 || Left square bracket lower corner || &amp;#9123;
|-
| U+23A4 || Right square bracket upper corner || &amp;#9124;
|-
| U+23A5 || Right square bracket extension || &amp;#9125;
|-
| U+23A6 || Right square bracket lower corner || &amp;#9126;
|-
| U+23A7 || Left curly bracket upper hook || &amp;#9127; ||rowspan="6"|
{|
| ⎧<br/>⎨<br/>⎩
| large curly brackets
| ⎫<br/>⎬<br/>⎭
|}
|-
| U+23A8 || Left curly bracket middle piece || &amp;#9128;
|-
| U+23A9 || Left curly bracket lower hook || &amp;#9129;
|-
| U+23AB || Right curly bracket upper hook || &amp;#9131;
|-
| U+23AC || Right curly bracket middle piece || &amp;#9132;
|-
| U+23AD || Right curly bracket lower hook || &amp;#9133;
|-
| U+23AA || Curly bracket extension || &amp;#9130; || ⎪
|-
| U+23B0 || Upper left or lower right curly bracket section || &amp;#9136; ||rowspan="2"| ⎰&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;⎱<br>⎱&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;⎰
|-
| U+23B1 || Upper right or lower left curly bracket section || &amp;#9137;
|-
| U+23B4 || Top square bracket || &amp;#9140; ||rowspan="2"|
{| style="text-align: center;"
|-
| ⎴
|-
| horizontal square brackets
|-
| ⎵
|}
|-
| U+23B5 || Bottom square bracket || &amp;#9141;
|-
| U+23B6 || Bottom square bracket over top square bracket || &amp;#9142; ||
{|style="text-align: center; font-style:monospace"
|-
| ⎴ || ⎴ || ⎴ || ⎴ || ⎴ || ⎴ || ⎴ || ⎴ || ⎴
|-
| t || e || r || m || i || n || a || l ||
|-
| ⎶ || ⎶ || ⎶ || ⎶ || ⎶ || ⎶ || ⎶ || ⎶ || ⎶
|-
| e || m || u || l || a || t || i || o || n
|-
| ⎵ || ⎵ || ⎵ || ⎵ || ⎵ || ⎵ || ⎵ || ⎵ || ⎵
|}
|-
| U+23B8 || Left vertical box line || &amp;#9144; ||rowspan="2"|⎸boxed text⎹
|-
| U+23B9 || Right vertical box line || &amp;#9145;
|-
| U+23DC || Top parenthesis || &amp;#9180; ||rowspan="2"|
{| style="text-align: center;"
|-
| &#9180;
|-
| horizontal parentheses
|-
| &#9181;
|}
|-
| U+23DD || Bottom parenthesis || &amp;#9181;
|-
| U+23DE || Top curly bracket || &amp;#9182; ||rowspan="2"|
{| style="text-align: center;"
|-
| &#9182;
|-
| horizontal curly brackets
|-
| &#9183;
|}
|-
| U+23DF || Bottom curly bracket || &amp;#9183;
|-
| U+23E0 || Top tortoise shell bracket || &amp;#9184; ||rowspan="2"|
{| style="text-align: center;"
|-
| &#9184;
|-
| tortoise shell brackets
|-
| &#9185;
|}
|-
| U+23E1 || Bottom tortoise shell bracket || &amp;#9185;
|-
| U+27C5 || Left s-shaped bag delimiter || &amp;#10181; ||rowspan="2"| ⟅…⟆
|-
| U+27C6 || Right s-shaped bag delimiter || &amp;#10182;
|-
| U+27D3 || Lower right corner with dot || &amp;#10195; ||rowspan="2"| ⟓pullback…pushout⟔
|-
| U+27D4 || Upper left corner with dot || &amp;#10196;
|-
| U+27E6 || Mathematical left white square bracket || &amp;#10214; ||rowspan="2"| ⟦white square brackets⟧
|-
| U+27E7 || Mathematical right white square bracket || &amp;#10215;
|-
| U+27E8 || Mathematical left angle bracket || &amp;#10216; &amp;lang;<ref name="lang-rang" group="e"/> ||rowspan="2"| {{angbr|''{{math|a}}'', ''{{math|b}}''}}
|-
| U+27E9 || Mathematical right angle bracket || &amp;#10217; &amp;rang;<ref name="lang-rang" group="e"/>
|-
| U+27EA || Mathematical left double angle bracket || &amp;#10218; ||rowspan="2"| ⟪''{{math|A}}'', ''{{math|B}}''⟫
|-
| U+27EB || Mathematical right double angle bracket || &amp;#10219;
|-
| U+27EC || Mathematical left white tortoise shell bracket || &amp;#10220; ||rowspan="2"| ⟬white tortoise shell brackets⟭
|-
| U+27ED || Mathematical right white tortoise shell bracket || &amp;#10221;
|-
| U+27EE || Mathematical left flattened parenthesis || &amp;#10222; ||rowspan="2"| ⟮flattened parentheses⟯
|-
| U+27EF || Mathematical right flattened parenthesis || &amp;#10223;
|-
| U+2983 || Left white curly bracket || &amp;#10627; ||rowspan="2"| ⦃white curly brackets⦄
|-
| U+2984 || Right white curly bracket || &amp;#10628;
|-
| U+2985 || Left white parenthesis || &amp;#10629; ||rowspan="2"| ⦅white/double parentheses⦆
|-
| U+2986 || Right white parenthesis || &amp;#10630;
|-
| U+2987 || [[Z notation]] left image bracket || &amp;#10631; ||rowspan="2"| ''{{math|R}}''⦇''{{math|S}}''⦈
|-
| U+2988 || Z notation right image bracket || &amp;#10632;
|-
| U+2989 || Z notation left binding bracket || &amp;#10633; ||rowspan="2"| ''{{math|A}}''⦉''{{math|B}}''⦊
|-
| U+298A || Z notation right binding bracket || &amp;#10634;
|-
| U+298B || Left square bracket with underbar || &amp;#10635; ||rowspan="2"| ⦋underlined square brackets⦌
|-
| U+298C || Right square bracket with underbar || &amp;#10636;
|-
| U+298D || Left square bracket with tick in top corner || &amp;#10637; ||rowspan="2"| ⦍ticked square brackets⦐
|-
| U+2990 || Right square bracket with tick in top corner || &amp;#10640;
|-
| U+298E || Right square bracket with tick in bottom corner || &amp;#10638; ||rowspan="2"| ⦏ticked square brackets⦎
|-
| U+298F || Left square bracket with tick in bottom corner || &amp;#10639;
|-
| U+2991 || Left angle bracket with dot || &amp;#10641; ||rowspan="2"| ⦑dotted angle brackets⦒
|-
| U+2992 || Right angle bracket with dot || &amp;#10642;
|-
| U+2993 || Left arc less-than bracket || &amp;#10643; ||rowspan="2"| ⦓[[Inequality (mathematics)|inequality]] sign brackets⦔
|-
| U+2994 || Right arc greater-than bracket || &amp;#10644;
|-
| U+2995 || Double left arc greater-than bracket || &amp;#10645; ||rowspan="2"| ⦕inequality sign brackets⦖
|-
| U+2996 || Double right arc less-than bracket || &amp;#10646;
|-
| U+2997 || Left black tortoise shell bracket || &amp;#10647; ||rowspan="2"| ⦗black tortoise shell brackets⦘
|-
| U+2998 || Right black tortoise shell bracket || &amp;#10648;
|-
| U+29D8 || Left wiggly fence || &amp;#10712; ||rowspan="2"| ⧘…⧙
|-
| U+29D9 || Right wiggly fence || &amp;#10713;
|-
| U+29DA || Left double wiggly fence || &amp;#10714; ||rowspan="2"| ⧚…⧛
|-
| U+29DB || Right double wiggly fence || &amp;#10715;
|-
| U+29FC || Left-pointing curved angle bracket || &amp;#10748; ||rowspan="2"| ⧼…⧽
|-
| U+29FD || Right-pointing curved angle bracket || &amp;#10749;
|-
|rowspan="4"| Half brackets<ref name="Supplemental Punctuation">{{citation | url=http://www.unicode.org/charts/PDF/U2E00.pdf | title=Supplemental Punctuation Code Chart | work=The Unicode Standard | accessdate=2016-02-27}}</ref>
| U+2E22 || Top left half bracket || &amp;#11810; ||rowspan="2"| ⸢''editorial notation''⸣
|-
| U+2E23 || Top right half bracket || &amp;#11811;
|-
| U+2E24 || Bottom left half bracket || &amp;#11812; ||rowspan="2"| ⸤''editorial notation''⸥
|-
| U+2E25 || Bottom right half bracket || &amp;#11813;
|-
|rowspan="14"| [[Dingbat]]s<ref>{{citation | url=http://www.unicode.org/charts/PDF/U2700.pdf | title=Dingbats Code Chart | work=The Unicode Standard | accessdate=2016-02-27}}</ref>
| U+2768 || Medium left parenthesis ornament || &amp;#10088; ||rowspan="2"| ❨medium parenthesis ornament❩
|-
| U+2769 || Medium right parenthesis ornament || &amp;#10089;
|-
| U+276A || Medium flattened left parenthesis ornament || &amp;#10090; ||rowspan="2"| ❪medium flattened parenthesis ornament❫
|-
| U+276B || Medium flattened right parenthesis ornament || &amp;#10091;
|-
| U+276C || Medium left-pointing angle bracket ornament || &amp;#10092; ||rowspan="2"| ❬medium angle bracket ornament❭
|-
| U+276D || Medium right-pointing angle bracket ornament || &amp;#10093;
|-
| U+2770 || Heavy left-pointing angle bracket ornament || &amp;#10096; ||rowspan="2"| ❰heavy angle bracket ornament❱
|-
| U+2771 || Heavy right-pointing angle bracket ornament || &amp;#10097;
|-
| U+276E || Heavy left-pointing angle quotation mark ornament || &amp;#10094; ||rowspan="2"| ❮heavy angle quotation ornament❯
|-
| U+276F || Heavy right-pointing angle quotation mark ornament || &amp;#10095;
|-
| U+2772 || Light left tortoise shell bracket ornament || &amp;#10098; ||rowspan="2"| ❲light tortoise shell bracket ornament❳
|-
| U+2773 || Light right tortoise shell bracket ornament || &amp;#10099;
|-
| U+2774 || Medium left curly bracket ornament || &amp;#10100; ||rowspan="2"| ❴medium curly bracket ornament❵
|-
| U+2775 || Medium right curly bracket ornament || &amp;#10101;
|-
|rowspan="2"| [[Arabic script|Arabic]]<ref>{{citation | url=http://www.unicode.org/charts/PDF/UFB50.pdf | title=Arabic Presentation Forms-A Code Chart | work=The Unicode Standard | accessdate=2016-02-27}}</ref>
| U+FD3E || Ornate left parenthesis || &amp;#64830; ||rowspan="2"| {{script/Arabic|&#xFD3F;&#x0627;&#x0644;&#x0639;&#x0631;&#x0628;&#x064A;&#x0629;&#xFD3E;}}
|-
| U+FD3F || Ornate right parenthesis || &amp;#64831;
|-
|rowspan="2"| [[N'Ko alphabet|N'Ko]]<ref name="Supplemental Punctuation"/>
| U+2E1C || Left low paraphrase bracket || &amp;#11804; ||rowspan="2"| {{script|Nkoo|⸜ߒߞߏ⸝}}
|-
| U+2E1D || Right low paraphrase bracket || &amp;#11805;
|-
|rowspan="2"| [[Ogham]]<ref>{{citation | url=http://www.unicode.org/charts/PDF/U1680.pdf | title=Ogham Code Chart | work=The Unicode Standard | accessdate=2016-02-27}}</ref>
| U+169B || Ogham feather mark || &amp;#5787; ||rowspan="2"| <big>᚛ᚑᚌᚐᚋ᚜</big>
|-
| U+169C || Ogham reversed feather mark || &amp;#5788;
|-
| [[Old Hungarian alphabet|Old Hungarian]] || U+2E42 || Double low-reversed-9 quotation mark || &amp;#11842;
|-
|rowspan="4"| [[Tibetan alphabet|Tibetan]]<ref>{{citation | url=http://www.unicode.org/charts/PDF/U0F00.pdf | title=Tibetan Code Chart | work=The Unicode Standard | accessdate=2016-02-27}}</ref>
| U+0F3A || Tibetan mark gug rtags gyon || &amp;#3898; ||rowspan="2"| <big>༺དབུ་ཅན་༻</big>
|-
| U+0F3B || Tibetan mark gug rtags gyas || &amp;#3899;
|-
| U+0F3C || Tibetan mark ang khang gyon || &amp;#3900; ||rowspan="2"| <big>༼༡༢༣༽</big>
|-
| U+0F3D || Tibetan mark ang khang gyas || &amp;#3901;
|-
|rowspan="8"| [[New Testament]] editorial marks<ref name="Supplemental Punctuation"/>
| U+2E02 || Left substitution bracket || &amp;#11778; ||rowspan="2"| ⸂…⸃
|-
| U+2E03 || Right substitution bracket || &amp;#11779;
|-
| U+2E04 || Left dotted substitution bracket || &amp;#11780; ||rowspan="2"| ⸄…⸅
|-
| U+2E05 || Right dotted substitution bracket || &amp;#11781;
|-
| U+2E09 || Left transposition bracket || &amp;#11785; ||rowspan="2"| ⸉…⸊
|-
| U+2E0A || Right transposition bracket || &amp;#11786;
|-
| U+2E0C || Left raised omission bracket || &amp;#11788; ||rowspan="2"| ⸌…⸍
|-
| U+2E0D || Right raised omission bracket || &amp;#11789;
|-
|rowspan="6"| [[Medieval studies]]<ref name="General Punctuation">{{citation | url=http://www.unicode.org/charts/PDF/U2000.pdf | title=General Punctuation Code Chart | work=The Unicode Standard | accessdate=2016-03-01}}</ref><ref name="Supplemental Punctuation"/>
| U+2045 || Left square bracket with quill || &amp;#8261; ||rowspan="2"|⁅…⁆
|-
| U+2046 || Right square bracket with quill || &amp;#8262;
|-
| U+2E26 || Left sideways u bracket || &amp;#11814; ||rowspan="2"| ⸦crux⸧
|-
| U+2E27 || Right sideways u bracket || &amp;#11815;
|-
| U+2E28 || Left double parenthesis || &amp;#11816; ||rowspan="2"| ⸨…⸩
|-
| U+2E29 || Right double parenthesis || &amp;#11817;
|-
|rowspan="10"| Quotation<br>(East-Asian texts)<ref name="CJK Symbols and Punctuation"/>
| U+3014 || Left tortoise shell bracket || &amp;#12308; ||rowspan="2"| 〔…〕
|-
| U+3015 || Right tortoise shell bracket || &amp;#12309;
|-
| U+3016 || Left white lenticular bracket || &amp;#12310; ||rowspan="2"| 〖…〗
|-
| U+3017 || Right white lenticular bracket || &amp;#12311;
|-
| U+3018 || Left white tortoise shell bracket || &amp;#12312; ||rowspan="2"| 〘…〙
|-
| U+3019 || Right white tortoise shell bracket || &amp;#12313;
|-
| U+301A || Left white square bracket || &amp;#12314; ||rowspan="2"| 〚…〛
|-
| U+301B || Right white square bracket || &amp;#12315;
|-
| U+301D || Reversed double prime quotation mark || &amp;#12317; ||rowspan="2"| 〝…〞
|-
| U+301E || Double prime quotation mark || &amp;#12318;<ref name="301E" group="e"/>
|-
|rowspan="4"| Quotation<br>(halfwidth East-Asian texts)<ref name="Unicode Miscellaneous Technical"/><ref name="Halfwidth and Fullwidth Forms"/>
| U+2329 || Left-pointing angle bracket || &amp;#9001; &amp;lang;<ref name="lang-rang" group="e"/> || rowspan="2" | 〈deprecated〉
|-
| U+232A || Right-pointing angle bracket || &amp;#9002; &amp;rang;<ref name="lang-rang" group="e"/>
|-
| U+FF62 || Halfwidth left corner bracket || &amp;#65378; ||rowspan="2"| 「カタカナ」
|-
| U+FF63 || Halfwidth right corner bracket || &amp;#65379;
|-
|rowspan="10"| Quotation<br>(fullwidth East-Asian texts)<ref name="CJK Symbols and Punctuation">{{citation | url=http://www.unicode.org/charts/PDF/U3000.pdf | title=CJK Symbols and Punctuation Code Chart | work=The Unicode Standard | accessdate=2016-02-27}}</ref>
| U+3008 || Left angle bracket || &amp;#12296; ||rowspan="2"| 〈한〉
|-
| U+3009 || Right angle bracket || &amp;#12297;
|-
| U+300A || Left double angle bracket || &amp;#12298; ||rowspan="2"| 《한》
|-
| U+300B || Right double angle bracket || &amp;#12299;
|-
| U+300C || Left corner bracket || &amp;#12300; ||rowspan="2"| 「白八櫨」
|-
| U+300D || Right corner bracket || &amp;#12301;
|-
| U+300E || Left white corner bracket || &amp;#12302; ||rowspan="2"| 『カタカナ』
|-
| U+300F || Right white corner bracket || &amp;#12303;
|-
| U+3010 || Left black lenticular bracket || &amp;#12304; ||rowspan="2"| 【ひらがな】
|-
| U+3011 || Right black lenticular bracket || &amp;#12305;
|-
|rowspan="4"| General purpose<br> (fullwidth East-Asian)<ref name="Halfwidth and Fullwidth Forms">{{citation | url=http://www.unicode.org/charts/PDF/UFF00.pdf | title=Halfwidth and Fullwidth Forms Code Chart | work=The Unicode Standard | accessdate=2016-02-27}}</ref>
| U+FF08 || Fullwidth left parenthesis || &amp;#65288; ||rowspan="2"| (Wiki)
|-
| U+FF09 || Fullwidth right parenthesis || &amp;#65289;
|-
| U+FF3B || Fullwidth left square bracket || &amp;#65339; ||rowspan="2"| [''sic'']
|-
| U+FF3D || Fullwidth right square bracket || &amp;#65341;
|-
|rowspan="6"| Technical/mathematical<br>(fullwidth East-Asian)<ref name="Halfwidth and Fullwidth Forms"/>
| U+FF1C || Fullwidth less-than sign || &amp;#65308; ||rowspan="2"| <HTML>
|-
| U+FF1E || Fullwidth greater-than sign || &amp;#65310;
|-
| U+FF5B || Fullwidth left curly bracket || &amp;#65371; ||rowspan="2"| {1、2}
|-
| U+FF5D || Fullwidth right curly bracket || &amp;#65373;
|-
| U+FF5F || Fullwidth left white parenthesis || &amp;#65375; ||rowspan="2"| ⦅…⦆
|-
| U+FF60 || Fullwidth right white parenthesis || &amp;#65376;
|}
 
=== WebAssembly ===
<references group="e">
[[WebAssembly]] is a newer language with a [[bytecode]] format designed to complement JavaScript, especially the performance-critical portions of [[web page]] scripts. All of the major [[JavaScript engine]]s support WebAssembly,<ref>{{cite web|url=https://visualstudiomagazine.com/articles/2017/11/06/edge-webassembly.aspx|title=Edge Browser Switches WebAssembly to 'On' -- Visual Studio Magazine|website=Visual Studio Magazine|access-date=2018-02-09|archive-date=2018-02-10|archive-url=https://web.archive.org/web/20180210002432/https://visualstudiomagazine.com/articles/2017/11/06/edge-webassembly.aspx|url-status=live}}</ref> which runs in the same [[Sandbox (computer security)|sandbox]] as regular JavaScript code.
<ref name="lang-rang">&amp;lang; and &amp;rang; were tied to the deprecated symbols U+2329 and U+232A in HTML4 and MathML2, but are being migrated to U+27E8 and U+27E9 for HTML5 and MathML3, as defined in [http://www.w3.org/TR/xml-entity-names/#diff-xhtml1 XML Entity Definitions for Characters].</ref>
<ref name="301E">This is fullwidth version of U+2033 DOUBLE PRIME. In vertical texts, U+301F LOW DOUBLE PRIME QUOTATION MARK is preferred.</ref>
</references>
 
[[asm.js]] is a subset of JavaScript that served as the forerunner of WebAssembly.<ref>{{cite web | url=https://asmjs.org/faq.html | title=frequently asked questions | publisher=asm.js | access-date=April 13, 2014 | archive-date=June 4, 2014 | archive-url=https://web.archive.org/web/20140604012024/https://asmjs.org/faq.html | url-status=live }}</ref>
Braces (curly brackets) first became part of a character set with the 8-bit code of the [[IBM 7030 Stretch]].<ref>{{cite web |last=Bob |first=Bemer |title=The Great Curly Brace Trace Chase |url=http://www.bobbemer.com/BRACES.HTM |accessdate =2009-09-05 |postscript=<!--None-->}}</ref>
 
== Notes ==
The angle brackets or chevrons at U+27E8 and U+27E9 are for mathematical use and Western languages, whereas U+3008 and U+3009 are for East Asian languages. The chevrons at U+2329 and U+232A are deprecated in favour of the U+3008 and U+3009 East Asian angle brackets. Unicode discourages their use for mathematics and in Western texts,<ref name="Unicode Miscellaneous Technical" /> because they are canonically equivalent to the CJK code points U+300x and thus likely to render as double-width symbols. The ''less-than'' and ''greater-than'' symbols are often used as replacements for chevrons.
{{notelist}}
 
==See alsoReferences ==
{{Reflist}}
* [[International variation in quotation marks]]
* [[Emoticon]]
* [[Japanese typographic symbols]]
* [[Order of operations]]
 
== Further reading ==
==References==
{{See also|ECMAScript#External_links|l1=ECMAScript Specification Documents}}
{{Reflist|30em}}
* {{cite book|last=Flanagan|first=David|title=JavaScript: The Definitive Guide|edition=7th|___location=Sebastopol, California|publisher=O'Reilly|year=2020|isbn=978-1-491-95202-3}}
* {{Cite book |title=Eloquent JavaScript |last=Haverbeke |first=Marijn |publisher=[[No Starch Press]] |isbn=978-1-71850-411-0 |edition=4th |___location=San Francisco |publication-date=2024 |url=https://eloquentjavascript.net/Eloquent_JavaScript.pdf |archive-url=https://web.archive.org/web/20250312193854/https://eloquentjavascript.net/Eloquent_JavaScript.pdf |archive-date=2025-03-12 |url-status=live}}
* {{cite book|last=Zakas|first=Nicholas|title=Principles of Object-Oriented JavaScript|edition=1st|publisher=No Starch Press|year=2014|isbn=978-1593275402}}
 
== External links ==
==Bibliography==
{{Sister project links|commons=Category:JavaScript|n=no|v=Topic:JavaScript|q=no|s=no|m=no|voy=no|species=no|mw=JavaScript}}
* {{cite book |authorlink=John Lennard |last=Lennard |first=John |title=But I Digress: The Exploitation of Parentheses in English Printed Verse |year=1991 |isbn=0-19-811247-5 |publisher=Clarendon Press |___location=Oxford}}
{{Spoken Wikipedia|En-JavaScript.ogg|date=August 20, 2013}}
* {{cite book |last=Turnbull |title=The Graphics of Communication |publisher=Holt |___location=New York |year=1964|display-authors=etal}} States that what are depicted as brackets above are called braces and braces are called brackets. This was the terminology in US printing prior to computers.
* [https://javascript.info/ The Modern JavaScript Tutorial]. A community maintained continuously updated collection of tutorials on the entirety of the language.
* {{cite web |url=https://www.pldi21.org/prerecorded_hopl.12.html |title=JavaScript: The First 20 Years |access-date=2022-02-06}}
 
{{JavaScript}}
==External links==
{{ECMAScript}}
*{{commons category-inline|Brackets (punctuation marks)|Brackets}}
{{Web browsers|fsp}}
*{{wiktionary-inline|bracket}}
{{NodeJs}}
{{Programming languages}}
{{Portal bar|Computer programming}}
{{Authority control}}
 
[[Category:PunctuationJavaScript| ]]
[[Category:MathematicalAmerican notationinventions]]
[[Category:Articles with example JavaScript code]]
[[Category:Cross-platform software]]
[[Category:Dynamically typed programming languages]]
[[Category:Functional languages]]
[[Category:Object-based programming languages]]
[[Category:High-level programming languages]]
[[Category:Programming languages created in 1995]]
[[Category:Programming languages with an ISO standard]]
[[Category:Prototype-based programming languages]]
[[Category:Scripting languages]]
[[Category:Web programming]]
[[Category:Programming languages]]