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

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

新規登録して質問してみよう
ただいま回答率
85.48%
JavaScript

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

1回答

2398閲覧

JavaScriptでリアルタイムプレビューができる電卓の開発は可能ですか?

退会済みユーザー

退会済みユーザー

総合スコア0

JavaScript

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2015/05/16 00:19

例えば1+2と入力したら2を入力した時点で答えが出てくる。といたものです。そして当然四則演算のルールに従い、式が長い,小数点がある計算にも対応できるという感じです。Androidの方は付属の電卓で同じようなのがあるかもしれませんがまさにそれです。可能ですか?それともJavaScriptではなくjQueryを使用するのですか?
参考リンクがあれば教えて下さい...

気になる質問をクリップする

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

こんにちは。

可能だと思います。

(1)ユーザーがキーボードの数字や四則演算の記号を打ったら、それを数式として
表示するHTML要素は、
<input type="text">
でもよいですし、あるいは
<span>
でもよいと思います。後でCSSでデザインしやすいものを選べばよいです。
さらに、計算結果を表示する要素も用意しておきます。

(2)JSのプログラムとしては、評価対象の数式を入れる変数を用意しておき、
画面ロード時はこの変数に空文字列を入れておきます。

(3)ユーザーがキーボードを打つたびに、その変数に(数式を構成する文字として有効な文字
ならば、)その文字を追加していき、1文字の追加ごとに式の評価(計算)を試みます。

(4)評価可能だったら、その結果を表示します。

アウトラインは上記のようなものになると想定しています。

以下は、ユーザーの入力と、プログラムの動きの簡単なシナリオです。

・たとえば、画面の初期表示後、最初にユーザーが「1」と打ったら、式全体は「1」です。
これはその電卓プログラムによって評価可能で、結果は 1 です。
なので、計算結果の表示欄にも「1」と表示します。

・次にユーザーが「+」を打つと、式全体は「1+」となって、これは評価できないということで、
計算結果の表示欄はクリアされます。

・次に「2」と打つと、式全体は「1+2」となって、これは評価でき、
計算結果の表示欄に「3」と表示します。

・・・といったように、ユーザーがキーボードで文字を打って、それが電卓プログラムとして
受け取れる文字である場合に、式の変数にその文字を追加して、式全体を評価して結果を表示
するというものにすればよいと思います。

このプログラムで少しハードルが高く、プログラマの腕の見せ所でもあると思う
部分はどこかというと、受け取れる文字として、数字、丸カッコ、四則演算の
記号に限っても、たとえば

1+2(3-4)+(5-6)/7*

という文字列を式とみて、この式の計算結果を正しく算出できるプログラムを
書くところです。これはそんなに易しくはないと思いますが、
「四則演算 構文木」
あたりで検索すれば、ヒントが見つかると思います。

以上、参考になれば幸いです。

投稿2015/05/16 00:54

編集2015/05/16 02:33
jun68ykt

総合スコア9058

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2015/05/16 01:02

とてもわかりやすく、ものすごく参考になりました!本当にありがとうございます!
jun68ykt

2015/05/16 02:15

参考になったとのことで嬉しいです! 以下補足です。 もしこの電卓プログラムの作成が、たとえば誰かから頼まれたもので 自分で式の評価プログラムを書く時間がないなら、式の評価を javascript組み込みの関数 eval() にお任せするというのも アリかもしれません。 回答に例として挙げた式をeval()で評価する以下のスクリプト <script> var expression = "1+2*(3-4)+(5-6)/7"; var result = eval(expression); console.log("result=" + result); console.log("typeof(result)=" + typeof(result) ); </script> を、自分の手元のChromeで実行すると、  result=-1.1428571428571428  typeof(result)=number と表示されました。 以上、今回の電卓の作成が、四則演算式を解析して評価するプログラムを 書くこと自体が目的ではないなら、eval()を使って済ませるという方法も あります、という補足でした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問