今注目のニュース
「NHKにせがた三四郎!?」と大反響
猫の魂が抜ける瞬間を激撮!? 幽体離脱しているような猫のお騒がせ写真が話題に
長男「おもらししたら先生に叩かれた」 母親の抗議に、園長が頼もしい反応!

JavaScript単語

ジャバスクリプト

掲示板をみる(75)
  • twitter
  • facebook
  • はてな
  • LINE

JavaScript(ジャバスクリプト)はスクリプト言語の一種。Webブラウザ上で動作させるためのスクリプトとして誕生した。

現在ECMAScriptが正式名称らしいが、その名を知る者は少ない。

概要

ニコニコ動画など、近年のWebサービスは見栄えや操作性を上げるためにJavaScriptを多用する傾向にある。JavaScriptに対応していない、または機を制限しているブラウザでそのようなページを閲覧する場合、制作者の意図した表示・動作にならないことがある。

プログラミング言語であるJavaとは名前が似ているため間違われやすく、また本屋などではJavaコーナーにJavaScript関連本が置かれていたりするが、実は全く別の言である。JavaScriptがNetscape Navigatorに搭載された当初はLiveScriptという名前だったが、当時Netscape Communications(現AOL)Sun Microsystems(現Oracle)と技術提携しており、アプレットというWebブラウザ上でJavaプログラムを動かす形態で当時人気だったJavaあやかってJavaScriptという名前に変更したらしい。

なお、JavaScriptは現在ではECMAScriptとして標準化された言の一般的な呼称である。ECMAScript実装例として、他にInternetExplorerJScriptやAdobe FlashActionScriptなどがある。

2000年前半まではスクリプト言語というチープ感やセキュリティ問題等であまり好まれていない言であったが、2005年googleマップ話題となり、Ajaxという名称がつけられた頃から、同期通信を可にするツールとして一気に注が集まった。

また2008年頃からWebデザインダイナミックな動きを与えるライブラリとしてjQuery世界的な人気となり、単にシステムだけでなく、デザインインターフェースはたまたPHPRailsにおけるAjax通信においても欠かせない言となった。

今日ではスマホが普及したことでWEBアプリ用用途としてJavaScript及びそれを発展させたフレームワークライブラリが開発に欠かせないものとなっており、”何でもできる”、から、更に速さと軽さというフットワークへの要に応えたものとなっている。そんな中で特に知られているのが、Facebookが開発し、JSXの記述方法に則ったコンポーネントライブラリであるReactGoogleが開発したAngularJSの開発メンバーが、より発展的なライブラリへと仕上げたVue.js世界的な注の的となっている。また、JavaScriptフレームワークとしてはAngularJSの欠点を発展的に解消させたらもはや別物となったAngular、軽さが売りのBackboneJSなどがある。

サンプルコード

Hello, World!

ブックマークレット

アドレスバーコピペで実行できる。新しくブックマークを作り、URLの代わりにこれを入すればいつでも呼び出せる(ブックマークレットと呼ばれる所以)。ニコニコ動画ハッキング系の動画でたまに見かける「javascript:」で始まる呪文がこれ。

javascript: alert("Hello, World!");

オブジェクト指向的な書き方

まずsomethingコンストラクタを作る。これはインスタンスnameプロパティを作り、仮引数nameの値を代入するというもの。次にsomethingコンストラクタのprototypeプロパティにhelloメソッドを追加。これはインスタンスnameプロパティを参照し、その前後に「Hello, 」と「!」をくっつけてダイアログに表示させるというもの。そして実際にworldという名前でsomethingコンストラクタのインスタンスを作る。この時の引数は'World'。最後にworldオブジェクトからhelloメソッドを呼ぶ。

function something(name) {
this.name = name;
}
something.prototype = {
hello: function() {
alert('Hello, ' + this.name + '!');
}
};
var world = new something('World');
world.hello();

ブラウザ以外の用途

ブラウザ以外ではアプリケーション用のスクリプト言語として使われている例がいくつもあり、特にAdobe製品ではほとんどの製品でJavaScriptによる拡や自動化ができるようになっている。

サーバーサイドでは1990年代後半から様々な製品やプロジェクトが存在しており、いずれも普及しているとはとてもいえない状態だったのだが、現在Node.jsが注を集めており、サーバーサイドJavaScript環境が個人の趣味レベルえる状態にはなっている。

またRDBの利点を多少をつぶることでその問題点をした非リレーショナルデータベースデータ形式にJSONを採用し、SQLの代わりにJavaScriptで問い合わせる形態のデータベースがいくつか登場している。

関連用語

NicoScript (ニワン語
戀塚昭彦氏の示でJavaScriptに似せて作られた。(日経ソフトウェア2008年5月号より)
Greasemonkey
Mozilla Firefoxのアドイン。JavaScriptを用いてウェブサイトを拡する。
ActionScript
Flashで使用される言。JavaScript(ECMAScript)を拡したもの。
TypeScript
MicrosoftがJavaScriptの上位互換として静的型付けにしたもの。

関連商品

関連項目

掲示板

急上昇ワード

最終更新:2019/08/17(土) 23:00

ほめられた記事

最終更新:2019/08/17(土) 23:00

ウォッチリストに追加しました!

すでにウォッチリストに
入っています。

OK

追加に失敗しました。

OK

追加にはログインが必要です。

       

ほめた!

すでにほめています。

すでにほめています。

ほめるを取消しました。

OK

ほめるに失敗しました。

OK

ほめるの取消しに失敗しました。

OK

ほめるにはログインが必要です。

TOP