--- title: JavaScriptでの基本演算 — 数値と演算子 slug: Learn/JavaScript/First_steps/Math tags: - Article - Beginner - CodingScripting - Guide - JavaScript - Learn - Math - Operators - augmented - increment - 'l10n:priority' - maths - modulo translation_of: Learn/JavaScript/First_steps/Math ---
今回は JavaScript での数学的処理についてです。我々の命令を実行するために上手く数値を操作するのにどのように {{Glossary("Operator","演算子")}} や、その他の機能を使用できるのかを見ていきましょう。
前提条件: | 基本的なコンピューターの知識、HTML と CSS の基本についての理解、JavaScript が何かが分かっていること。 |
---|---|
目的: | JavaScript での基礎的な数値処理に慣れる。 |
まあ、みんなではないですね。好きな人もいれば、九九や長い数字の割り算が出てきてから嫌いになってしまった人もいるでしょう。どちらでもない人も。けれど、数学が生活に必要なものであるということは、否定することは出来ません。特に JavaScript のプログラミングを学習しているのなら、なおさらです。数値データを処理したり、計算をしたりすることが多いので、JavaScript に数学的な関数が十分にそろっていることは、驚くことではありません。
この記事ではまず知っておくべき基礎的なものに絞って見ていきます。
プログラミングをしていると、慣れ親しんだ普通の数値ですら難しいと思えるかもしれません。数値と言ってもいくつか種類があり、それぞれ名前を付けて区別しています。
さらに通常とは異なる数値表現も使います!今まで出てきた数値は 10 を基数 (0 ~ 9 を 1 つの桁として扱う) とした十進数でしたが、他にも以下のようなものがあります。
脳みそが溶けそうだと思う前に、少し待ってください!まず、この講座では十進数しか扱いません。それに「もしかすれば」ですが、他の数値表現について考える機会は訪れないということだってあり得ます。
さらにちょっといいことを教えましょう。いくつかの他のプログラミング言語とは違い、JavaScript には数値(整数と少数の両方)を表すデータ型が一つしかありません。わかりますか?{{jsxref("Number","Number (数値)")}} で、これは整数と小数の両方です。これはJavaScript でどんな型の数値を扱おうとも、それらを全く同じように扱うことが可能だということを意味します。
記: 実際に、JavaScript には 2 つ目の数値型である{{Glossary("BigInt")}} があり、これはとても大きな整数に使います。しかしこのコースの目的としては、Number
の値だけに関心を持つことにします。
書き方の復習を兼ねてちょっと数字で遊んでみましょう。以下に示すコマンドを開発者ツールの JavaScript コンソール入力してみましょう。もちろんこのページに埋め込みのコンソールを使っても構いません。
var myInt = 5; var myFloat = 6.667; myInt; myFloat;
typeof myInt; typeof myFloat;どちらの変数についても
"number"
という文字が戻ってきましたね。もし、別々の数値型が存在しているとすれば、別々に処理しなければならないので、そう考えるととても簡単に思えますよね!Number
オブジェクトは、あなたが JavaScript を使う時すべての基本的な数値を表現するインスタンスですが、その中には、数値を操作するための沢山の便利なメソッドがあります。この記事では、簡単な紹介と基本的な要点だけまとめたいので、詳しくは割愛しますが、この段落を何回か読んだら、オブジェクト参照ページに行って、どんなメソッドが使えるのかを勉強するのが良いと思います。
例えば、数値を固定の桁数に丸めるには toFixed()
メソッドを使用します。ブラウザのコンソールに次の行を入力します。
let lotsOfDecimal = 1.766584958675746364; lotsOfDecimal; let twoDecimalPlaces = lotsOfDecimal.toFixed(2); twoDecimalPlaces;
たまに、文字列型として格納されている数字で計算ができなくなってしまうことがあります。これは、データがフォーム入力に入力され、input タイプが text である場合によく起こります。この問題を解決する方法があります - 文字列の値を Number()
コンストラクタに渡して、同じ値の数値バージョンを返します。
例えば、これらの命令をコンソールに入力してみてください。
let myNumber = '74'; myNumber + 3;
答えは 743 です。77 ではありません。 なぜなら myNumber
は string として定義されているからです。以下の命令で確認することができます。
typeof myNumber;
これは以下のようにして修正することができます。
Number(myNumber) + 3;
算術演算子は JavaScript で計算をするのに使用する最も基本的な演算子です。
演算子 | 名前 | 目的 | 例 |
---|---|---|---|
+ |
加算 | 左項と右項を足す。 | 6 + 9 |
- |
減算 | 左項より右項の数を引く。 | 20 - 15 |
* |
乗算 | 左項と右項を掛ける。 | 3 * 7 |
/ |
除算 | 左項の数値を右項で割る。 | 10 / 5 |
% |
剰余 (モジューロともいう) |
左項を右項で割った余りを求める。 |
8% 3 (8 を 3 で割ったとき、商 2 余り 2 の 2 ですね) |
** |
指数 |
|
5 ** 2 ( 25 を返します。その値は 5 * 5 と同じですね) |
メモ: 演算子 (オペレーター) に必要とされる数のことを{{Glossary("Operand", "オペランド")}}と呼ぶことがあります。
メモ: 指数が古い {{jsxref("Math.pow()")}} メソッドを使って表現されているのを見ることがあるかもしれませんが、それはとてもよく似た働きをします。たとえば、Math.pow(7, 3)
では、7
が基底で 3
が指数であるため、式の結果は 343
になります。Math.pow(7, 3)
は 7**3
と同じです。
たぶん基本的な数学を教える必要はないでしょうが、ここに出てくる文法を理解しているかをテストしたいと思います。書き方を覚えるため、以下に示す例を開発者ツールの JavaScript コンソールに入力してみましょう。
10 + 7 9 * 8 60 % 3
let num1 = 10; let num2 = 50; 9 * num1; num1 ** 3; num2 / num1;
5 + 10 * 3; num2 % 9 * num1; num2 + num1 / 8 + 2;
最後の例の中に予想した結果と違う答えがありませんでしたか。次の章でなぜそうなったかを説明してみましょう。
先ほどの計算式の一番最後の例を見てみましょう。num2
に 50、num1
に 10 が格納されているものとします。(最初はそうでしたよね。)
num2 + num1 / 8 + 2;
ある人は、先に「50 + 10 = 60」と「8 + 2 = 10」を先に計算して、その後で「60 ÷ 10 = 6」となるように計算するかもしれません。
けれどもブラウザは「10 ÷ 8 = 1.25」を先に計算してから「50 + 1.25 + 2 = 53.25」を計算します。
どうしてこうなるのかといえば、演算子には優先順位があるからです。ある演算子は (プログラムの式によっては) 他の演算子よりも先に実行されます。JavaScript の演算子の優先順位は算数の授業で教わったものと同じです。つまり、乗算と除算は常に最初に行われ、それから加算と減算が実行されます(通常の計算は常に左から右に評価されます)。
もし、演算子の優先順位を変更したいならば、先に実行したい部分を括弧 (()
) を使って囲みます。もし先ほどの例で 6 が答えになるようにしたいなら次のようにします。
(num2 + num1) / (8 + 2);
実際に実行し、結果を見てみてください。
メモ: JavaScript の演算子とその優先順位については式と演算子で確認することができます。
たまに、繰り返し値を足したり引いたりしたいときがあるでしょう。そんなときに便利なのがインクリメント演算子 (++
) とデクリメント演算子 (--
) です。もう既に、JavaScript への最初のダイブに出てくる「数字当てゲーム」で、ユーザーの残り予想回数を求めるために使用する guessCount
変数に 1 を加えるのに ++
を使用しましたね。
guessCount++;
メモ: これらの演算子は、このコースの後で学ぶ繰り返し処理でよく使われます。例えば、価格の一覧があって、それに対して掛かる税金を各要素に足していきたいとします。恐らく繰り返し処理を使用して、それぞれの価格に対して必要な計算をすることになるでしょう。そのときに、次の値に移動するためインクリメント演算子を使用します。どのように行うかを説明する簡単な例をご用意しました。— インクリメント演算子に興味を持ったらライブで実行、およびソースコードの閲覧をしてみてください。繰り返しについては、このコースの後で詳細を見てみます。
それでは、コンソールで試してみましょう。ただし、その前に注意点です。この演算子は数値には直接使用できません。変に思えるかもしれませんが、これは対象の値そのものに作用するわけではなく、変数に対して新しい値を代入するのです。次の例はエラーになります。
3++;
既に存在する値に対してのみインクリメントすることができます。
let num1 = 4; num1++;
また変なことが起きましたね!上のコードを実行したとき「4」がコンソールに表示されました。これはブラウザが現在の値を先に返して、その後にインクリメントを実行したためです。もう一度変数を入力してみると、変数がインクリメントされていることがわかります。
num1;
それは --
演算子についても同様です。以下のコードも試してみてください。
var num2 = 6; num2--; num2;
メモ: 変数の前に演算子を置くことで、ブラウザにインクリメントまたはデクリメントを先にさせてから値を戻すようにすることもできます。上記の例に戻って今度は ++num1
や --num2
のように入力してみてください。
代入演算子は変数に値を代入します。すでに一番基本的な =
演算子を何度も使用しています。この演算子は単に左辺に記述された値を右辺に代入します。
let x = 3; // x には 3 が入る let y = 4; // y には 4 が入る x = y; // x には y と同じ値:4 が入る
ただし、コードを簡潔に効率よく書くための、もっと複雑な方法が用意されています。よく見かけるものを以下に示します。
演算子 | 名前 | 目的 | 例 | 同様のコード |
---|---|---|---|---|
+= |
加算代入 | 右辺の値を左辺の変数値に加算してから、新しい値を返します | x += 4; |
x = x + 4; |
-= |
減算代入 | 右辺の値を左辺の変数値より減算してから、新しい値を返します | x -= 3; |
x = x - 3; |
*= |
乗算代入 | 左辺の変数値に右辺の値を乗算してから、新しい値を返します | x *= 3; |
x = x * 3; |
/= |
除算代入 | 左辺の変数値を右辺の値で除算してから、新しい値を返します | x /= 5; |
x = x / 5; |
どのように動いているか理解するため、コンソールに上記の例をいくつか入力してみましょう。どの例も、2 行目を入力する前にコードがどのようになるかを予想してから入力しましょう。
ちなみに、どの演算子も右辺には自由に変数を置くことができます。例えば以下のように。
let x = 3; // x には 3 が入る let y = 4; // y には 4 が入る x *= y; // x は 12 になる
メモ: もっとたくさんの代入演算子がありますが、とりあえず今は基本的なものだけ知っておけばよいでしょう。
練習として、数値と演算子を使用してボックスのサイズを変更してみましょう。ブラウザの {{domxref("Canvas API", "", "", "true")}} を使用してボックスを描きます。どうやって描くかについて気にする必要はありません。今は計算に集中しましょう。ボックスの幅と高さ (ピクセル単位で) 変数 x
と y
で宣言しています。最初は 50 になっています。
{{EmbedGHLiveSample("learning-area/javascript/introduction-to-js-1/maths/editable_canvas.html", '100%', 620)}}
上の編集可能なコードには、変更すべき 2 つの行にコメントが書かれています。その行を適切な演算子および値を用いて変更し、拡大縮小させてください。それではやってみましょう。
コードを完全に壊してしまっても大丈夫です。いつでもリセットボタンを押すことで何度でも最初から実行できます。上の問題に全問正解したら、もう少し遊んでみてもいいですし、自分で問題を作ってみてもいいですね。
ときには、true または false を判定し、その結果により動作を変更したいと思う時があるでしょう。そのようなことをするために比較演算子を使用します。
演算子 | 名前 | 目的 | 例 |
---|---|---|---|
=== |
厳密な等価 | 右辺と左辺が厳密に同一の値であるかを判定します | 5 === 2 + 4 |
!== |
厳密な不等 | 右辺と左辺が厳密に同一の値ではないことを判定します | 5 !== 2 + 3 |
< |
小なり | 左辺の値が右辺の値より小さいこととを判定します | 10 < 6 |
> |
大なり | 左辺の値が右辺の値より大きいことを判定します | 10 > 20 |
<= |
以下なり | 左辺の値が右辺の値以下であることを判定します | 3 <= 2 |
>= |
以上なり | 左辺の値が右辺の値以上であることを判定します | 5 >= 4 |
メモ: もしかしたら ==
や !=
といった演算子を同値かどうかの判定に使用する人を見かけることがあるかもしれません。これらも JavaScript の有効な演算子ですが、===
や !==
とは異なります。前者のバージョンは値が同様であるかを判定しますが、データ型が同様かは判定しません。後者は厳格なバージョンで値とデータ型の両方を判定します。厳格なバージョンはエラーとなることが少ないため後者を使用することをお勧めします。
もし、これらの値をコンソールに入力したら、すべて true または
false
の値を返します。これは前回の記事で言及した、真偽値です。真偽値はとても便利です。コードで判断をすることを可能にしてくれます。また選択肢を選ぶときには毎回使うことになるでしょう。例えば以下のような場合に。
後の記事にて、条件文でどのようにロジックをコーディングするのかを見ていきます。とりあえずの簡易な例で見てみましょう。
<button>起動する</button> <p>マシンは停止中です。</p>
const btn = document.querySelector('button'); const txt = document.querySelector('p'); btn.addEventListener('click', updateBtn); function updateBtn() { if (btn.textContent === '起動する') { btn.textContent = '停止する'; txt.textContent = 'マシンが起動しました!'; } else { btn.textContent = '起動する'; txt.textContent = 'マシンは停止中です。'; } }
{{EmbedGHLiveSample("learning-area/javascript/introduction-to-js-1/maths/conditional.html", '100%', 100)}}
等価演算子が updateBtn()
関数の中で使用されていることがわかりますね。今回の場合は数値が同じ値かを判定するためには使用していません。ボタンの内容として設定されている文字列が、特定の文字列であるかどうかを比較しています。ただし、原理的には同じ働きです。もしボタンに「起動する」と書かれていれば、押されたときにボタンのラベルが「停止する」に代わります。もしボタンに「停止する」と書かれていれば、再度入れ替わって元に戻ります。
メモ: 2 つの状態を行き来するこのような操作を一般的にトグルといいます。スイッチの ON/OFF のように、ある状態がもう一つの状態にトグル (切り替え) するといいます。
この記事の終わりまで到達しましたが、最も大事な情報を覚えていますか?移動する前に、この情報を取得したかのテストを見ることができます — Test your skills: Math を見てください。
この記事では、JavaScript の数値処理で知っておくべき基礎的なことを学びました。JavaScript を学習する間、今後も繰り返し数値を扱うことになるので、しっかりと復習しておきましょう。数学が好きではなくとも、この章はとても短いので安心して (復習して) ください。
次の章では文字列と、文字列を JavaScript で操作する方法について見ていきます。
メモ: もし数学が好きで、JavaScript にどう実装されているかをもっと知りたいのであれば、MDN の JavaScript のメインの章に詳細がたくさん載っています。まずは数値と日付や式と演算子辺りの記事から読むのがいいでしょう。
{{PreviousMenuNext("Learn/JavaScript/First_steps/Variables", "Learn/JavaScript/First_steps/Strings", "Learn/JavaScript/First_steps")}}