JavaScript基礎


JavaScriptとは

JavaScriptはブラウザ上で実行されるスクリプト言語(ソースコードを記述することで即座に動作できるようなプログラム言語のこと)として誕生し,現在ではそれ以外にもサーバー側で動作するnode.jsのような環境も登場しています。このJavaScriptをブラウザ側で実行することで,フォームに入力された値の確認,ページ内の要素にアニメーションや効果を加えたりなど,いろいろな処理が可能になります。ブラウザごとに差異はありますが,現在では国際的な標準化団体の一つであるECMA(エクマ) Internationalにおいて規格が策定されているので,ECMAscriptという名前で呼ばれることもあります。

名前が似たJavaという言語がありますが,全くの別物です。JavaScriptのことを"Java"と略して呼ぶのは止めましょう。

JavaScriptをWebページで使用する際には,基本として

ということを覚えておいてください。

外部のファイルを読み込む方法もありますが,ここでは最初,直接JavaScriptコードをHTMLファイルに埋め込む方法をとります。

プログラムを実行してみる

まずは,適当なコードを実行してみて動作確認をしてみましょう。上でも説明したように,<script>タグの中にコードを記述していきます。

コード

結果

説明

ここでwindow.alert('Hellow, World!');は,警告ダイアログを表示させるための文です。文法については後で説明していきます。 もし,ダイアログが表示されない場合はブラウザの設定でJavaScriptが有効になっているか確認してみてください。

変数

変数の宣言

JavaScriptでは,変数は最初に使うタイミングで自動的に確保されますが,var 変数名;というように明示的に変数の宣言をすることもできます。下の画像ではhogeという変数に1234というデータを代入しています。

配列

配列とは,1つの変数に複数のデータをまとめて入れられる仕組みの1つです。配列に格納されたデータは「要素」と呼ばれ,自動的に1つずつ先頭から番号がふられます。

この番号は「インデックス」と呼ばれ,先頭は0から始まります。インデックスは,個別にデータを引き出したいときなどに使います。

配列の作成

変数に複数のデータを配列として格納するには,このように記述します。

配列の要素の参照

要素を指定してデータを引き出す際はこのように記述します。

たとえば,aという変数に,配列hogeの先頭から2番目に格納されている222というデータを代入したいときは下記のように記述します。

関数とは

関数とは,あらかじめ定めた処理をひとまとめにして定義することで,処理を使いまわせるようにしたものです。関数を定義するためにはfunction文を使います。関数名は変数と同じように任意の名前をつけることが出来ます。

関数の使用例

上の説明だけではわかりにくいので,実際に使ってみます。

コード

結果

説明

引数

引数とは,簡単にいうと関数内の変数へ代入する値で,function文の()内に記述することで指定することが出来ます。これを使うことで,関数に様々な値を渡すことができます。

引数の使用例

コード

説明

スコープ

スコープとは,変数が有効な範囲のことです。普通にプログラムで宣言した変数はプログラムのどこでも有効となります。(プログラム全体がスコープ)この変数のことをグローバル変数といいます。

それに対し,関数の中でvarを用いて変数を宣言した場合は,関数の中でのみ有効な変数となります。(関数の中がスコープ)これをローカル変数といいます。ローカル変数は関数の外で値を代入したり,参照することが出来ません。

ちなみに,関数の中でグローバル変数を宣言したい場合はvarをつけずに宣言することで可能です。

関数の定義方法

ここまで関数の勉強をしてきましたが,最初の方法以外にも関数を定義する方法があるので紹介していきます。

宣言して定義

これは最初に勉強した方法です。この方法で宣言した関数のことを宣言型の関数といいます。

変数に代入

次に,変数に代入して宣言する方法です。この場合,関数名は書かずに宣言します。この書き方を関数リテラル,無名関数といいます。

コンストラクタ

最後に,コンストラクタを使用する方法を紹介します。まず,コンストラクタとは右側のnew Function('仮引数','処理');の部分のことで,これも一応変数に代入して宣言しています。これを説明するには組み込みオブジェクトの話が必要となってくるため,ここではこういうものがある,ということだけ覚えておいてください。

オブジェクトとは

変数の中にはデータを直接代入するだけでなく,変数や関数を代入して使うことも出来ます。これをオブジェクトといい,中に入った変数やデータはプロパティ,関数はメソッドと呼ばれます。プロパティにはそれぞれプロパティ名をつけて管理します。

ちなみに,オブジェクトは下の画像のコードのように入れ子にすることもできます。今回はlistオブジェクトの中に2つのプロパティ(id, name)とaddressオブジェクトを代入しています。

このオブジェクトの仕組みを樹形図にするとこのようになります。

上記のlistオブジェクトのデータを取り出すJavaScriptは例えば次のようになります。

 これを実行すると,listオブジェクトのnameプロパティとaddressオブジェクト(プロパティ)の中のmailプロパティが下記のように表示されます。


Copyright (c) 2014-2022 幸谷研究室 @ 静岡理工科大学 All rights reserved.
Copyright (c) 2014-2022 T.Kouya Laboratory @ Shizuoka Institute of Science and Technology. All rights reserved.