HTML中のJavaScript。scriptタグやbodyタグで囲まれている。JavaScript(ジャバスクリプト)は、プログラミング言語であり、HyperText Markup Language(HTML)やCascading Style Sheets(CSS)と並ぶ World Wide Web(WWW)の中核技術の一つである。JavaScriptで書かれたプログラムはHTMLやCSSと同様に、ウェブサービスのクライアントであるウェブブラウザ上で、解釈・実行される。
プロトタイプベースのオブジェクト指向スクリプト言語であるが、クラスなどのクラスベースに見られる機能も取り込んでいる。
利用される場面はウェブサイト、ウェブアプリケーション、バックエンド、デスクトップアプリケーション、モバイルアプリケーションなど、ウェブブラウザからサーバ、デスクトップパソコンからスマートフォンまで多岐にわたっている。
Javaと似た名称を持つが、異なるプログラミング言語である(#歴史を参照)。
JavaScriptはWebブラウザNetscape Navigatorに起源を持ち、現在では様々な用途に利用されるプログラミング言語である。
JavaScriptの言語仕様はECMAScriptとして標準化され、実装は各種のJavaScriptエンジンによって提供されている。JavaScriptエンジンの例としてChromium系ブラウザのV8、Mozilla FirefoxのSpiderMonkey、SafariのJavaScriptCoreが挙げられる。
言語仕様を定義するECMAScriptのほかに、WebブラウザへアクセスするためのAPI仕様にDOMなどがある。これらはECMAScriptから独立しており、JavaScriptからも独立した概念である。
JavaScriptは以下のような様々なスタイルのプログラミングが可能である。
これらを可能にしているプログラミング言語としての特徴に、以下のことが挙げられる。オブジェクト指向の面では、JavaScriptのオブジェクトはクラスベースではなくプロトタイプベースである[注釈 1]。関数型の面では、第一級関数をサポートし関数を第一級オブジェクトとして扱える。
AptanaやEclipse、NetBeans、IntelliJ IDEAなどの統合開発環境はJavaScriptをサポートしており、大規模開発が可能になっている。さらにExt JSなどの本格的なGUIライブラリの登場により、デスクトップアプリケーションと遜色ないユーザインタフェースの構築が可能になった。
JavaScriptではしばしば、ネットワークを介したリクエストのような "待ち" がある処理を行う[注釈 2]。これに対処するために非同期処理をサポートし並行処理が可能となる。標準で用意されている処理機能にも非同期処理されるものがある。
非同期処理を記述する方法としてコールバック関数がある。JavaScriptはコールバック関数記法をラップするPromise、Promiseを同期的なコードのように記述できるAsync/await構文をもつ。
またJavaScriptは並列処理による並行処理もサポートしている(下記参照)。
JavaScriptでは複数スレッドを用いた並列処理が可能である。共有メモリ上のバッファを表現するSharedArrayBuffer、バッファ操作オブジェクトAtomicsが定義されている。スレッドそのものの仕様は環境ごとに異なる(ECMAScriptでは定義されていない)。ブラウザの場合はWorker、Node.jsの場合はworker_threadsで定義されている。ただこの2環境ではほぼ共通の仕組みとなっており、例えばpostMessageによるメッセージングが両者でサポートされている。
JavaScriptはネットスケープコミュニケーションズのブレンダン・アイクによって、1995年5月に10日間で開発された。上司からの指示に「Javaのような外観にしてくれ」「初心者に優しく」「Netscapeブラウザのほとんどなんでも制御できるように」との注文があった[3]。Netscape Navigator 2.0で実装された。
開発当初はLiveScriptと呼ばれていたが、1995年にサン・マイクロシステムズ(現・オラクル)が開発したプログラミング言語Javaが当時大きな注目を浴びており、ネットスケープとサン・マイクロシステムズが業務提携していた事もあったため、JavaScriptという名前に変更された[4][5]。最初のJavaScriptエンジンはアイクによりNetscape Navigatorのために作成されたものであった。このエンジンはSpiderMonkeyと呼ばれており、C言語で実装されていた。また、全てJavaで記述されたJavaScriptエンジンであるRhinoも同じくNetscapeのNorris Boyd(後にGoogleに移籍)らにより作成された。
1996年にマイクロソフトのInternet Explorer 3.0にJScriptという名前で搭載されるようになると、その手軽さからJavaScriptは急速に普及していく。1997年、通信に関する標準を策定する国際団体EcmaインターナショナルによってJavaScriptの中核的な仕様がECMAScriptとして標準化され[6]、多くのウェブブラウザで利用できるようになった。
ネットスケープは、ウェブアプリケーション開発言語として自社のサーバ製品に実装したLiveWire JavaScriptも発表したが[5]、こちらはあまり普及しなかった。
JavaScriptの登場初期は、ブラウザベンダー間で言語仕様の独自拡張が行われていたため、ブラウザ間の互換性が極めて低かった。ECMAScriptの策定以降は実装間の互換性は向上し、DOMなど関連仕様の実装に関する互換性も高くなっていった。
かつてはJavaScriptという言葉が「ECMAScript標準」を指す、あるいは「独自実装を含んだ広義のJavaScript」を指し幅広い意味で使われていた。ゆえにどちらの意味でJavaScriptという言葉が使われているかは文脈で判断する必要があった[7]。たとえばかつてマイクロソフトによる実装はJScriptと呼ばれたが、JScriptをJavaScriptと呼ぶような場面があった。
ECMAScriptは仕様自体に独自の拡張を条件付きで認める記述があり[8]、ブラウザが実装しているスクリプト言語はすべてECMAScriptに準拠していることになる。広義の意味でこれをJavaScriptと呼ぶ場合、主要なブラウザが実装しているスクリプト言語はマイクロソフトやGoogle、Appleの実装も含めてJavaScriptである。
実装間での差異を吸収するためにPrototype JavaScript Frameworkなどのライブラリが用いられた。
市場のブラウザ間互換性がある程度確立された2000年ごろには、GoogleやAmazonなどのGAFAMもJavaScriptを積極的に利用し始めた。
また、JavaScriptはウェブブラウザの拡張機能を開発するための言語としても使われるようになった。当初は拡張機能用のAPIが統一されていなかったが、互換性を高めようとする動きがある[9]。
当初は単純なインタプリタで実行されることが一般的であったためJavaScriptの実行速度はさほど速くなかったが、現在ではJITコンパイルなどを利用した高度なインタプリタとなっており、各ウェブブラウザのベンダーともに高速化を図ってしのぎを削っている。さらには、この高速化を受ける形で、Node.jsのようにサーバサイドでもJavaScriptを使う動きが見られるようになった。
次世代のJavaScriptとして、"JavaScript 2.0"を作ろうとした動きは二度あったが、いずれもまとまらなかった。
1度目はECMAScript 3が完成したのち2000年から2003年にかけて発生したが、ネットスケープとマイクロソフトの対立でまとまらなかった。当時ネットスケープが提案していた案はアドビのActionScript 2.0に引き継がれ、マイクロソフトの案はJScript .NETへと引き継がれた。
その後もネットスケープ及びMozilla FoundationはECMAScriptの策定に並行してJavaScriptを拡張し、JavaScript 1.x系列としてバージョンアップを繰り返していた。ECMAScript側ではECMAScript 4の策定が1999年以降進められており[10]、2006年の時点でMozilla Foundationはこれに基づいてJavaScript 2.0を作成することを表明していた。MozillaはECMAScript 4の策定にあたって、Pythonの文法を一部取り込んだ案を提案しており、自身でもこれを実装していた[11]。
しかしその後、ECMAScriptの標準化作業がMozilla, Adobe, Opera, Googleらが推す ECMAScript 4 と、Microsoft, Yahoo! らが推す ECMAScript 3.1 に事実上分裂してしまった影響から、2008年8月に大きな方針転換があり、ECMAScript 4は破棄され後者がECMAScript 5として2009年に標準化された。ECMAScript 4に入る予定だった機能は新たに発足した「ECMAScript Harmony」に先送りとなった[12]。これは後にECMAScript 2015として標準化が完了した。
なお、ECMAScript 5が標準化されて以降、MozillaのJavaScript実装はECMAScriptへの準拠を謳うようになった[13]。そしてバージョン番号での呼称は行われなくなり、JavaScript 2.0は事実上死語となった。
JavaScriptの変数はvar[14],let[15]およびconst[16] キーワードを使用して宣言できる。
letx;// 変数xの宣言。値が未指定のため、特殊な値である undefined が入った状態となる。lety=2;// 変数yの宣言。同時に 2 が代入される。constz=5;// 定数zの宣言。同時に 5 が代入される。定数であるため、書き換えることはできない。
上記例のスラッシュ2文字以降はコメントである。
JavaScriptは言語仕様にI/Oが組み込まれておらず、それらは実行環境により提供される。ECMAScript 5.1の仕様では以下のように言及されている。[17]
この仕様の中では外部データの入力または計算結果の出力は供給しない。
(… indeed, there are no provisions in this specification for input of external data or output of computed results.)
しかし、ほとんどの実行環境はConsole Standard[18]で規定されているconsole オブジェクトを持っており[19]、そこにコンソール出力を行える。以下に最小のHello worldプログラムを示す。
console.log("Hello World!");再帰関数は以下のように書ける。
functionfactorial(n){if(n==0){return1;}returnn*factorial(n-1);}無名関数(またはアロー関数)の構文とクロージャの例は以下である。
// ECMAScript 5以前の記法vardisplayClosure=function(){letcount=0;// ECMAScript 2015以降で可能な記法return()=>{return++count;};}varinc=displayClosure();inc();// 1 が返るinc();// 2 が返るinc();// 3 が返る可変長引数は以下のように記述する[20]。
varsum=function(...args){letx=0;for(constvofargs){x+=v;}returnx;}sum(1,2,3);// 6 が返る即時実行関数式 (IIFE) の例。関数を用いることで変数をクロージャに閉じ込めることができる。
varv;v=1;vargetValue=(function(v){returnfunction(){returnv;};})(v);v=2;getValue();// 1 が返る以下のサンプルコードは、様々なJavaScriptの機能を示したものである。
"use strict";// strictモードの宣言/* 2つの数値の最小公倍数を求める */functionLCMCalculator(x,y){// コンストラクタ関数constcheckInt=(x)=>{// 入れ子の関数if(x%1!==0){thrownewTypeError(x+" is not an integer");// 例外のスロー}returnx;};// 行末のセミコロンは省略可能な場合があるが、省略は推奨されない。this.a=checkInt(x)this.b=checkInt(y);}// オブジェクトのプロトタイプはコンストラクタ関数の prototype プロパティに格納するLCMCalculator.prototype={// オブジェクトリテラルconstructor:LCMCalculator,// このようにプロトタイプを上書きする場合は、// constructorプロパティにコンストラクタ関数名を再指定するgcd:function(){// 最大公約数を計算するメソッド// 「ユークリッドの互除法」アルゴリズムで計算leta=Math.abs(this.a),b=Math.abs(this.b);if(a<b){// 変数の入れ替えconstt=b;b=a;a=t;}while(b!==0){constt=b;b=a%b;a=t;}// 最大公約数の計算は一度でよいため、自分自身を計算済みの結果を返すメソッドで再定義(上書き)する。// (これにより LCMCalculator.prototype.gcd の代わりに this.gcd が呼ばれるようになる。// ただし、計算後にプロパティ a や b が変更されてしまうと、結果は誤りとなる。)// なお 'gcd' === "gcd", this['gcd'] === this.gcd である。this['gcd']=function(){returna;};returna;},lcm:function(){// 最小公倍数を計算するメソッド// 変数名は、オブジェクトのプロパティと衝突しない。例)lcm は this.lcm とは異なる。// 以下では、浮動小数の精度の問題を避けるために this.a * this.b としていない。constlcm=this.a/this.gcd()*this.b;// 最小公倍数の計算も一度でよいため、自分自身を計算済みの結果を返すメソッドで再定義(上書き)する。this.lcm=function(){returnlcm;};returnlcm;},toString:function(){// toStringはオブジェクトを文字列に変換するときに呼ばれるメソッド。// テンプレート文字列により文字列中に値を埋め込むことができる。return`LCMCalculator: a =${this.a}, b =${this.b}`;}};// 汎用の出力関数の定義。この実装はWebブラウザ上でのみ動作する。functionoutput(x){document.body.appendChild(document.createTextNode(x));document.body.appendChild(document.createElement('br'));}// 無名関数はさまざまな書き方が可能[[25,55],[21,56],[22,58],[28,56]].map(([a,b])=>newLCMCalculator(a,b))// 配列リテラル + マッピング関数.sort((a,b)=>a.lcm()-b.lcm())// 指定した比較関数を用いたソート.forEach(obj=>{output(obj+", gcd = "+obj.gcd()+", lcm = "+obj.lcm());});上記コードをウェブブラウザ上で実行すると、以下の結果が表示される。
LCMCalculator: a = 28, b = 56, gcd = 28, lcm = 56LCMCalculator: a = 21, b = 56, gcd = 7, lcm = 168LCMCalculator: a = 25, b = 55, gcd = 5, lcm = 275LCMCalculator: a = 22, b = 58, gcd = 2, lcm = 638
JavaScriptはコードの最上階層に属するグローバルオブジェクトを提供している。JavaScriptにおけるグローバルオブジェクトはglobalThisである[21]。
それぞれのJavaScript実行環境において様々なAPIが存在しており、JavaScriptからそれらを呼び出すことができる。
HTML要素をJavaScriptから操作するためのDOM API(例:document.querySelector)、HTTPリクエストを送信するFetch API、マルチスレッドを可能にするWeb Workerなどが定義されている。これらは言語仕様であるECMAScriptからは独立した各々の仕様書でAPIが定義され、ブラウザ実装がJavaScriptバインディングを提供することでJavaScriptからの呼び出しが可能になっている。
ファイルシステムにアクセスするためのfs API(モジュール)や実行プロセスと相互作用するprocess APIなどが定義されている。Webブラウザがもつ強いサンドボックス要件が緩和されている点がNode.js APIの特徴の1つである。
alternative JavaScript (altJS) はJavaScriptへトランスパイルされるプログラミング言語の総称である。
JavaScriptへ新たな機能を追加する方法の1つに、新しい言語を定義しそのコードをJavaScriptへ変換する方法がある。そのようなJavaScriptへトランスパイルされる言語はaltJSと総称される。altJSの例としてCoffeeScriptやTypeScript、PureScriptが挙げられる。altJSを用いることで、新たな演算子や記法を導入し効率の良いJavaScript開発を行うことができる。素のJavaScriptはaltJSと対比してVanilla JSとしばしば呼ばれる[22]。
例えば、altJSの1つであるTypeScriptは型の導入を可能にする。JavaScriptは動的型付けであり、静的コード解析でJavaScriptコードへの型検査は実行可能だが、コード上に型表記をおこなうことはできないため、完全な型検査を行うことは難しい。TypeScriptはJavaScriptへ型ノーテーションを導入しトランスパイル時に型検査をおこなうことで、型をもったJavaScriptを実現している。
JavaScriptエコシステムには、再利用可能なコードをまとめた多様なライブラリ(パッケージ)が存在する。これらのパッケージの導入・バージョン管理・依存関係の解決を担うソフトウェアとしてnpmやyarnがあり、これらはNode.js環境と共にインストールされることがある。開発者はこれらのツールを利用して、package.jsonファイルでプロジェクトの依存パッケージを宣言的に管理する。
現代のJavaScript開発では、書かれたコードをそのままブラウザで実行するのではなく、最適化や互換性維持のために「ビルド」と呼ばれる処理を行うのが一般的である。このビルドプロセスは様々なツールによって支えられている。
近年のJavaScriptでは、コードを機能ごとにファイル分割するモジュールシステム(ES Modules)が標準的に利用される。モジュールバンドラは、これらの分割された多数のJavaScriptファイルと、それらが依存するパッケージを解析し、ブラウザでの実行に最適化された少数のファイルにまとめる(バンドルする)ためのツールである。これにより、ブラウザからのHTTPリクエスト回数を削減し、ページの表示速度を向上させることができる。代表的なモジュールバンドラとしてWebpack、Vite、Rollup などがある。
トランスパイラは、あるプログラミング言語で書かれたソースコードを、別のプログラミング言語のソースコードに変換するツールである。JavaScriptの文脈では主に二つの目的で利用される。
- ECMAScriptの新しいバージョンで書かれたコードを、古いブラウザでも実行可能な旧バージョンの構文に変換する。これにより、開発者は最新の言語機能を使用しつつ、幅広い環境での互換性を維持できる。この目的で最も広く使われているのがBabelである。
- altJSで記述されたコードをJavaScriptに変換する。
リンターは、ソースコードを静的解析し、文法的な誤り、潜在的なバグ、コーディングスタイルの規約違反などを検出・報告するツールである。チーム開発においてコードの品質と一貫性を保つ上で重要な役割を果たす。ESLint がデファクトスタンダードとなっている。
また、フォーマッタは、コードの見た目(インデント、改行、スペースなど)をあらかじめ定められたルールに従って自動で整形するツールであり、Prettier が利用されている。
JavaScriptは単体で完結するだけでなく、他の技術と連携することでWebアプリケーションの能力を拡張する。特に、WebAssemblyとJSONは現代の開発において重要な役割を担っている。
WebAssembly(ウェブアセンブリ、略称: Wasm)は、ウェブブラウザで実行可能なバイナリ形式の命令セットアーキテクチャである。JavaScriptを置き換えるものではなく、JavaScriptと協調して動作するように設計されている。
C言語、C++、Rustといった言語で書かれたソースコードをWasmにコンパイルすることで、これまでJavaScriptでは難しかったCPU負荷の高い処理(例: 3Dグラフィックス、ビデオエンコーディング、大規模な科学技術計算)を、ネイティブに近い速度でウェブブラウザ上で実行できる。
JavaScriptの役割は、Wasmモジュールの読み込み、コンパイル、およびインスタンス化を行うことである。一度インスタンス化されると、JavaScriptからWasmの関数を呼び出し、逆にWasmからJavaScriptの関数を呼び出すことが可能になる。このように、JavaScriptがアプリケーション全体の制御やDOM操作といったUI層を担当し、Wasmがパフォーマンスが要求される計算処理を担当するという分業が実現できる。
JSON (JavaScript Object Notation)
[編集]JSON(JavaScript Object Notation)は、JavaScriptのオブジェクトリテラル記法をベースにした、軽量なデータ交換フォーマットである。その出自からJavaScriptと非常に親和性が高く、現代のWeb APIにおけるデータ交換の標準的な形式となっている。
ウェブアプリケーションにおいて、ブラウザで動作するJavaScriptがfetch() APIなどを用いてサーバーと非同期通信を行う際、サーバーからの応答データはJSON形式の文字列で返されることが多い。JavaScriptには、このJSONを扱うための組み込みオブジェクトJSONが用意されている。
JSON.parse(): サーバーから受け取ったJSON形式の文字列を、JavaScriptが直接操作できるオブジェクトに変換する。JSON.stringify(): JavaScriptのオブジェクトを、サーバーに送信するためのJSON形式の文字列に変換する。
このシームレスな変換機能により、JavaScriptはサーバーとの間で複雑なデータを容易に送受信することができる。
WebブラウザにおけるHTML操作を目的として作られたJavaScriptは、2020年現在幅広い領域で利用されている。
JavaScriptの最も歴史の長い使用法はHTMLページにクライアント側のふるまいを持たせることである。これは当初はダイナミックHTML (DHTML)として知られていた。JavaScriptはHTMLに直接埋め込まれまたは別のファイルからインクルードされ、Webブラウザ上のJavaScript実行環境で動作する。Webブラウザは通常、Document Object Model(DOM)を扱うためのホストオブジェクトを提供する。
JavaScriptの使用例としては、以下のようなものがある。
JavaScriptはユーザーのブラウザ上で動作できることから、ユーザーの操作に対して素早く反応することができ、アプリケーションをよりレスポンシブにすることができる。さらにJavaScriptはHTML単独では対応できない操作、例えばキー入力などにも応答することができる。Gmailのようなアプリケーションでは、JavaScriptでUIロジックを実装し、さらにJavaScriptでサーバから情報(例えばeメールのメッセージ)を取得することで、こうしたメリットを享受している。このような利点からAjaxは大きなトレンドとなった[要出典]。
様々な言語やフレームワークをウェブブラウザ上で動作させるために、JavaScriptはそれらのコンパイル先出力言語となっている(例:TypeScript)。
以下はJavaScriptとDOMを含むWebページのごく単純な例である。
<!DOCTYPE html><htmllang="ja"><head><metacharset="utf-8"/><title>単純な例</title></head><body><h1id="header">これはJavaScriptです</h1><script>document.body.appendChild(document.createTextNode('Hello World!'));leth1=document.querySelector('#header');// id='header'の<h1>要素の参照を取得。h1=document.querySelectorAll('h1')[0];//または<h1>要素を全て取得してそこから先頭を取得。</script><noscript>お使いのブラウザはJavaScriptをサポートしていないか、無効になっています。</noscript></body></html>
ウェブブラウザ以外のJavaScript実行環境も存在する(サーバーサイドJavaScript実装の一覧(英語版)を参照)。データベースやWebサーバに組み込まれ、それらのAPIやHTTPリクエストやレスポンスのアクセスが提供されているものもある。
また、Node.jsのようにOSの機能(ネットワークやファイルシステムなど)にアクセスできる環境も存在する。加えてElectronなどのアプリケーションフレームワークの登場により、Atomなどのアプリケーションが広まりつつある。
いくつかのアプリケーションではマクロ言語としても採用されている。例えばAdobe Acrobatは、JavaScriptによるマクロ機能を搭載している。
JavaScriptは主にクライアントサイドのウェブブラウザ上で実行されるため、ユーザーの安全を保護するために厳格なセキュリティモデルが実装されている。言語自体に脆弱性があるわけではないが、その利用方法によってはセキュリティ上のリスクを生む可能性があるため、JavaScript開発者はいくつかの基本的な概念を理解することが重要である。
同一生成元ポリシー(Same-Origin Policy)は、ウェブブラウザにおける最も基本的なセキュリティ機構である。これは、あるオリジンから読み込まれた文書やスクリプトが、他のオリジンから読み込まれたリソースに対してアクセスすることを制限するものである。
具体的には、あるウェブサイト上で動作するJavaScriptが、fetch() APIやXMLHttpRequestオブジェクトを用いて別のオリジンのサーバーにAPIリクエストを送信しようとしても、ブラウザはこの通信をブロックする。同様に、JavaScriptから他のサイトのDOM構造に直接アクセスすることもできない。このポリシーは、悪意あるサイトで実行されるJavaScriptが、ユーザーがログイン中の銀行サイトなどの情報を不正に取得することを防ぐための、ブラウザがJavaScriptに課す重要な制約である。
クロスサイトスクリプティング(Cross-Site Scripting, XSS)は、ウェブアプリケーションの脆弱性を利用して、悪意のあるスクリプトを信頼されたウェブサイト上で実行させる攻撃手法である。
これは特に、JavaScriptを用いて動的にHTMLをページに挿入する際に、ユーザーの入力を無害化(サニタイズ)せずに扱うことで発生する。
// 脆弱なJavaScriptコードの例constuserInput='<img src="invalid" onerror="alert(\'XSS Attack!\')">';constcontainer=document.getElementById('comment-container');// .innerHTML を使うと、userInput内の文字列がHTMLとして解釈される。// この結果、onerror属性に仕込まれたJavaScriptコードが実行されてしまう。container.innerHTML=userInput;このように、攻撃者の用意した任意のJavaScriptコードがサイトの権限で実行されてしまうと、セッション情報の窃取やページの改ざんといった被害に繋がりうる。これを防ぐには、ユーザーの入力を文字列としてのみ扱いたい場合、innerHTMLの代わりにtextContentプロパティを用いるなど、意図しないJavaScriptの実行を避ける実装が求められる。
コンテンツセキュリティポリシー(Content Security Policy, CSP)は、XSSをはじめとする特定の種類の攻撃を検知し、影響を軽減するためのセキュリティレイヤーである。これは、JavaScriptの実行をより厳格に制御する機能を提供する。
ウェブサイトの管理者は、信頼できるJavaScriptファイル(.js)の取得元ドメインをHTTPヘッダでホワイトリスト指定できる。これにより、許可されていないドメインからのスクリプト読み込み(<script src="...">)はブラウザによって拒否される。
| バージョン | 日付 | 規格 | Netscape Navigator | Mozilla Firefox | Internet Explorer | Opera | Safari |
|---|
| 1.0 | 1996年3月 | | 2.0 | | 3.0 | | |
| 1.1 | 1996年8月 | | 3.0 | | | | |
| 1.2 | 1997年7月 | | 4.0-4.05 | | | | |
| 1.3 | 1998年10月 | ECMA-262 1st edition / ECMA-262 2nd edition | 4.06-4.7x | | 4.0 | 5.0 | |
| 1.4 | | | Netscape Server | | | 6.0 | |
| 1.5 | 2000年11月 | ECMA-262 3rd edition | 6.0 | 1.0 | 5.5 (JScript 5.5), 6.0 (JScript 5.6), 7.0 (JScript 5.7), 8.0 (JScript 6.0) | | |
| 1.6 | 2005年11月 | 1.5 + Array extras + Array and String generics + E4X | 7.0-8.0 | 1.5 | | 7.0-9.0 | 3.0, 3.1 |
| 1.7 | 2006年10月 | 1.6 + Pythonic generators + Iterators + let | | 2.0 | | | 3.2-5.1 |
| 1.8 | 2008年7月 | 1.7 + Generator expressions + Expression closures | | 3.0 | | | |
| 1.8.1 | | 1.8 + Minor Updates | | 3.5 | | | |
| 1.9 | | 1.8.1 +ECMAScript 5[24] Compliance | | 4.0-11.0 | | | |
[25]
代表的なJavaScriptライブラリは以下のとおり。
「JavaScript」は米国では、米国オラクルの商標である[26][27][28]。この商標はもともと1997年5月6日にサン・マイクロシステムズに発行され、2009年にオラクルがサンを買収した際に譲渡された[29]。
2024年9月にはライアン・ダールが先頭に立ってオラクルにJavaScript商標の解放を求める書簡が回覧された[30]。JavaScriptの生みの親であるブレンダン・アイクもこの取り組みを支持した14,000人以上の署名者の1人だった。
- ^新しい (ES2015以降) JavaScriptではクラスの構文によりプロトタイプを意識せずにオブジェクト指向プログラミングをすることが可能になったが、言語設計はプロトタイプベースの設計を維持している。
- ^もしも待ちの間にプログラムを停止/sleep させると、その間に他の処理をそのスレッドで行うことが出来ない(ブロッキング)。もしネットワークリクエストが返ってくるまでブロッキングしたとすると、その間ブラウザのレンダリングも停止してしまう。
|
|---|
| 低水準言語 | |
|---|
| 高水準言語 | | 1950年代 | |
|---|
| 1960年代 | |
|---|
| 1970年代 | |
|---|
| 1980年代 | |
|---|
| 1990年代 | |
|---|
| 2000年代 | |
|---|
| 2010年代 | |
|---|
| 2020年代 | |
|---|
|
|---|
| 架空の言語 | |
|---|
|