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

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

ただいまの
回答率

90.84%

  • Java

    12848questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • JSP

    868questions

    JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

  • サーブレット

    115questions

    サーブレット(Servlets)とはウェブやアプリケーションサーバー上に動くプログラムのことであり、ウェブブラウザや他のHTTPクライエントとデータベースやHTTPサーバー上のアプリケーションの中間層としての働きをします。

電卓アプリケーションの作成方法がわからず困っています

受付中

回答 2

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 169

smileymiley

score 4

 前提・実現したいこと

今年からSEとして働き始めたものです。

ただいま電卓を作成をしています。
その中でhtmlでモック画面は作ったのですが、いざコードを書くとなったところで、どうやったら画面上のボタンを押してそのボタンの数字や記号を計算結果表示欄に表示できるのかがわかりません。
よって画面上のボタンをクリックすることで数値や記号を表示するには、どのような考え方でどのようなコードを書けば良いのか教えていただきたいです。

ちなみにネットで調べるとJavaScriptのコードばかり出てくるのですが、JavaScriptはまだ書いたことがないため、サーブレット・jsp・Javaを組み合わせて作りたいです。
それともやはりJavaScriptでないとできないのでしょうか。。。

初心者でわからないことが多く初歩的な質問かもしれませんが、どうぞよろしくお願いいたします。

 該当のソースコード

<モック画面>

<!DCTYPE html>
<head>
  <meta charset="UTF-8">

<title>電卓</title>
</head>
<body>
<p>
</p>
<table border="2px">
    <tr>
        <th colspan="5" align="right"><div id="output">0</div></th>

    </tr>
    <tr>
        <form method="post" name = "clear" action="Calculator.html">
        <td><input type="button" value="7"></td>
        <td><input type="button" value="8"></td>
        <td><input type="button" value="9"></td>
        <td colspan="2" align="center"><input type="submit" name = "clear" value="    C    "></td>
        </form>
    </tr>
    </tr>
    <tr>
        <td><input type="button" value="4"></td>
        <td><input type="button" value="5"></td>
        <td><input type="button" value="6"></td>
        <td align="center"><input type="button" value="×"></td>
        <td align="center"><input type="button" value="÷"></td>
    </tr>    
    <tr>
        <td><input type="button" value="1"></td>
        <td><input type="button" value="2"></td>
        <td><input type="button" value="3"></td>
        <td><input type="button" value="+"></td>
        <td><input type="button" value="-"></td>
    </tr>
    <tr>
        <td><input type="button" value="0"></td>
        <td><input type="button" value=" ・ "></td>
        <td><input type="button" value="√ "></td>
        <td><input type="button" value="%"></td>
        <td><input type="button" value="="></td>
    </tr>
</table>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • mts10806

    2018/06/20 16:23

    プログラムコード(およびエラーメッセージ)は質問内容としては最も重要な部分であるため、見やすくしていただけると助かります。<code>ボタン押下→「コード」部分にコードを貼り付け→「ここに言語を入力」に対象言語名記入(エラーメッセージの場合は不要)の手順で「コードハイライト化」してください。(質問編集画面ではリアルタイムでプレビューが表示されるので見ながら調整してください)

    キャンセル

  • smileymiley

    2018/06/20 16:30

    初めて書いたため、不備があり申し訳ありませんでした。ご指摘いただきありがとうございます。書き直したので、ご確認いただけますと幸いです。

    キャンセル

  • mts10806

    2018/06/20 16:58

    「JavaScriptはまだ書いたことがない」とのことですがサーブレットについてはどの程度把握されているのでしょうか。

    キャンセル

回答 2

0

結論から言えば、JavaScriptを使わないと無理です。
Webページで画面を構築するには、HTML、CSS、JavaScriptの3つが必要となります。
特にボタンを押したら、特定の処理するといった事は、JavaScriptでしか出来ません。
電卓を作るだけでDBに保存するなどが必要ないのであれば、サーバサイド(サーブレット、JSP)は不要です。
というよりも、まずこの3つの知識があいまいとか、全然分からないという感じではサーブレット、JSPはまだ早いのではないでしょうか。

ネットで断片的な知識を拾っても、ろくに身に付きません。
ググるにしても、最低限の知識と応用力が必要です。
特にお仕事して、プログラミングをするのであれば体系立てて学習したほうが絶対にいいです。
JavaScriptの簡単な入門書を買って、勉強したほうが時間効率が良いと思いますよ。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

前置きですが、サーブレットをやるのであればWeb側の技術を習得していくこととなります。JavaScriptは避けて通れない技術なので、その辺りはきちんと認識しておいてください。

サーブレットで行うには対象のサーブレット側にリクエストを送らなければなりません。

基礎的なところを説明している記事は下記。

電卓の要件(簡略)は下記ですね。

  1. 数字ボタンを押したら押した数字が順番に画面に表示される
  2. 途中で+など演算のボタンを押したら対もう一方の数字を入力するモードに切り替わる(最初の数字と押された演算ボタンを保管しておく)
  3. 数字ボタンを押したら最初から数字が順番に画面に表示される
  4. 「=」を押すと保管しておいた数字と今打った数字の足し算を行い、結果を画面に表示する

ただし、
ルートや%などボタンを置かれていますが、まずは四則演算のみ実装していくと良くべきです。
ただの電卓とはいえ、実は足し算だけでも最初は苦労します。
結果を元に次の演算を行うこともありますよね?

ということで、実現のために越えるべき課題は以下。
(むしろ詳細設計書の一歩前くらいの項目です)


  1. 数字ボタンを押したら押した数字をサーブレットに送信し受け取ってとりあえずprintで表示
  2. 1.の数字を画面に返して表示させる
  3. 次にボタンを押したら1.で押した数字もあわせてサーブレットに送信し、1.で押した数字の後ろに数字を連結して1.→2.の順で実行
    ※ヒントですが、送信するためには例えばtype=hiddenなどのform内要素で持っておく必要があります。いっそtype=textとかnumberでreadonlyにしておいても良いかと思います。
  4. +ボタンを押したら演算を+モードとして保持し、現在の入力値を別途保持する
  5. 数字ボタンを押したら1.のときと同じで画面に表示し、元の数字は見た目上破棄する
  6. 3.と同じ
  7. =を押したら4.で保持しておいた数値と現在の数値を足し算 1.と同じ
  8. 足した結果を3.と同じく表示させる

本来は小数点の計算も入ってくると思いますし、
整数の計算だと0123など頭が0の数値はNGとしなければなりませんが、
ひとまず、まずは基本部分を上記の要領で作ってみてください。
必ず1つ1つ確かめながらやること。

・・・とここまで読むとおそらく「サーバーとのリクエスト・レスポンスを持っておかないといけないからあまりサーブレットでやる意味が無いな・・・」と思うかもしれませんが、実はその通りです。
データベースアクセスやメール送信など「サーバー側でしかできないこと」をやるのでなければ、サーブレットのメリットが活かせません。
ただ、サーブレットを利用してデータの保持やリクエスト・レスポンスを扱うための勉強にはなりますので、実戦的かどうかはともかく、損はないかと思います。

がんばってください。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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

  • Java

    12848questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • JSP

    868questions

    JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

  • サーブレット

    115questions

    サーブレット(Servlets)とはウェブやアプリケーションサーバー上に動くプログラムのことであり、ウェブブラウザや他のHTTPクライエントとデータベースやHTTPサーバー上のアプリケーションの中間層としての働きをします。