質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.84%

  • JavaScript

    14800questions

    JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

  • HTML

    8056questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • CSS

    5148questions

    CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

jsで電卓を作りたい

解決済

回答 1

投稿

  • 評価
  • クリップ 2
  • VIEW 176

nonnon8.

score 7

初心者ですが、電卓を作りたいです。
デザインは作ったのですが、手本のサイトを見てやってみているのですが動きません。
要素の名前の取得が間違っているとか、よくわからないところが多くあるので
教えてください。

ひとまずボタンを押すとテキストエリアに表示されるようにしたいのですが、どこがおかしいのか
よくわからない状態です…

最終的には電卓として使えられれば問題無いです。
よろしくお願いします。

<!DOCTYPE html>
<html lang="ja">
  <head>
    <meta charset="utf-8">
    <title>*</title>
    <link rel="stylesheet" href="style.css">
  </head>

  <body>
    <div class="back">
      <textarea id="monitor"></textarea>

      <div class="number_button">

        <div class="one_floor">
        <input id="b0" type="button" value="0" onclick="myValue(0)">
        <input id="b1" type="button" value="1" onclick="myValue(1)">
        <input id="b2" type="button" value="2" onclick="myValue(2)">
        <input id="b3" type="button" value="3" onclick="myValue(3)">
      </div>

      <div class="two_floor">
        <input id="b4" type="button" value="4" onclick="myValue(4)">
        <input id="b5" type="button" value="5" onclick="myValue(5)">
        <input id="b6" type="button" value="6" onclick="myValue(6)">
        <input id="b7" type="button" value="7" onclick="myValue(7)">
      </div>

      <div class="thr_floor">
        <input id="b8" type="button" value="8" onclick="myValue(8)">
        <input id="b9" type="button" value="9" onclick="myValue(9)">
        <input id="b10" type="button" value="+" onclick="myCalculate('+')">
        <input id="b11" type="button" value="-" onclick="myCalculate('-')">
      </div>

      <div class="fo_floor">
        <input id="b12" type="button" value="*" onclick="myCalculate('*')">
        <input id="b13" type="button" value="/" onclick="myCalculate('/')">
        <input id="b14" type="button" value="=" onclick="myCalculate('=')">
      </div>

      <div class="fif_floor">
        <input id="b15" type="button" value="C" onclick="myC()">
      </div>

      </div>

      <div class="exp">
      <p>Please put in number</p>
      <p>This is the calucuration.</p>
    </div>

    </div>
    <script src="cal.js"></script>
  </body>

</html>
.back{
  background: #aaaab0;
  height:900px;
  width:500px;
  margin-top: 50px;
  margin-left: 300px;
}

#monitor{
  height:80px;
  width:400px;
  margin-left: 45px;
  margin-right: 45px;
  margin-top: 10px;
  font-size: 60px;
  font-weight: bold;
  text-align: right;
  padding-top: 10px;
}

.one_floor,.two_floor,.thr_floor,.fo_floor{
  margin-top: 10px;
  display:block;
  float:left;

}

.fif_floor{
  margin-top: 10px;
  display:block;
  float:left;
}


#b0,#b1,#b2,#b3,#b4,#b5,#b6,#b7,#b8,#b9,#b10,#b11,#b12,#b13,#b14{
  height:100px;
  width:100px;
  text-align: center;
  font-size: 60px;
  background: #fcc800;
  margin: 10px;
  float:left;

}

#b15{
  height:100px;
  width:300px;
  text-align: center;
  font-size: 60px;
  background: #fcc800;
  margin: 10px;
  float:left;
}


.exp{
  font-size: 20px;
  float:left;
  font-weight: bold;
  text-align: center;
}
(function(){
  'use strict';

  let myInput="";
  let myTotal=0;
  let myCalc="+";
  let myFlg=1; //0:数字 1:演算子

  //数値を入力した時のルーチン
  //演算処理のルーチン
  //myValue()
  //myCalculate()

  function myValue(myData){
      myFlg=0; //1回前に入力したのは数値
      myInput+=myData; //現在入力している値に追加
      document.getElementById('monitor').value=myInput; //現在入力している値を表示
  }

  function myCalculate(myData){
    if(myflg===0){
        myFlg=1;
        myWork=myTotal+myCalc+myInput;
        myTotal=eval(myWork);
        myInput = "";    // 現在入力している値をクリア
        document.getElementById('monitor').value = myTotal;    // 合計を表示
        }
        if (myData == "="){    // 演算ボタンは[=]か?
        myTotal = 0;    // 合計をクリア
        myCalc = "+";    // 演算子を[+]とする
        }else{    // 演算ボタンは[=]以外である
        myCalc = myData;    // 演算子を退避させておく
        }

    }

    function myC(){    // クリアボタン[C]を押した
      myTotal = 0;    // 合計クリア
      myCalc = "+";    // 演算子クリア
      myInput = "";    // 現在入力している値をクリア
      document.getElementById('monitor').value = myTotal;    // つまり、0を表示
      }


})();
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+4

ひとまずボタンを押すとテキストエリアに表示されるようにしたいのですが

とりあえず以下で囲んである部分を取り除き、囲まない形にしますか。
そしたら、入力した数字は出てくるはずです。

(function(){
    'use strict';
    ...
})();

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/04/18 19:44

    ありがとうございます!
    'use strict'=厳格に?
    全体をfunction(){}で囲む理由がよくわかりませんが教えてもらえないでしょうか?
    'use strict'はなんの制限となっているのでしょうか

    キャンセル

  • 2018/04/19 00:50

    'use strict'は厳格モードで、的確なエラーチェックができる。
    http://analogic.jp/use-strict/
    (function(){ ... })();とすることで、スコープが作成される
    (今回の場合は、グローバルでアクセスできる位置に変数を置かなければならない)
    http://analogic.jp/immediate-function/

    と言ったところでしょうか。

    キャンセル

  • 2018/04/19 22:24

    ありがとうございます^^

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.84%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • JavaScript

    14800questions

    JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

  • HTML

    8056questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • CSS

    5148questions

    CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。