【JavaScript】小数点以下を四捨五入(round)、切り捨て(floor)、切り上げ(ceil)

■小数点以下の四捨五入・切り捨て・切り上げ

小数点以下の四捨五入、切り捨て、切り上げを行う場合は、それぞれ、「Math.round()」、「Math.floor()」、「Math.ceil()」を使用する。

・四捨五入

document.write(Math.round(3.5));
// 4
document.write(Math.round(3.4));
// 3

・切り捨て

document.write(Math.floor(3.5));
// 3
document.write(Math.floor(3.4));
// 3

・切り上げ

document.write(Math.ceil(3.5));
// 4
document.write(Math.ceil(3.4));
// 4

■作成するプログラムの概要

・HTMLの画面にてJavaScriptを実装する。

・テキストボックスに値を入力する。

・ラジオボタンで「そのまま」、「四捨五入」、「切り捨て」、「切り上げ」を選択する。

・「実行」ボタン押下時、記入した数字およびラジオボタンの選択結果に応じて、「そのまま」、「四捨五入」、「切り捨て」、「切り上げ」の処理を実行する。

■フローチャート

■プログラム仕様

 

処理名少数点以下の四捨五入、切り上げ、切り捨て処理
処理概要「実行」ボタン押下時、テキストボックスに入力した数値について、
ラジオボタンで選択した区分で、小数点以下の処理を分ける
引数なし
戻り値なし

 

入力処理内容出力
【テキストボックス】
検索文字列
入力した値を取得する。
入力した数値を数値型に変換する。(float型) 
【ラジオボタン】
処理区分
ラジオボタンを設定したform要素を取得する。
取得したform要素の中から、ラジオボタン要素を取得する。
取得したラジオボタン要素から、値を取得する。
出力用のdiv要素を取得する。
▼条件分岐
|【ラジオボタン:そのまま】
|入力値をそのまま表示する。①
-----
|【ラジオボタン:四捨五入】
|入力値の小数点第1位を四捨五入して表示する。②
-----
|【ラジオボタン:切り捨て】
|入力値の小数点第1位を切り捨てて表示する。③
-----
|【ラジオボタン:切り上げ】
|入力値の小数点第1位を切り上げて表示する。④
【innerHTML】
①そのまま
②四捨五入
③切り捨て
④切り上げ

■画面レイアウト

・【入力値】に数字を入力する。

・【小数点以下の処理】配下のラジオボタンにて、処理区分を選択する。

・「実行」ボタン押下時、【処理結果】に記入した数字およびラジオボタンの選択結果に応じて、「そのまま」、「四捨五入」、「切り捨て」、「切り上げ」の処理を実行する。

■サンプルコード

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>小数点以下</title>
</head>
<body>
    <!-- ここにjavascriptを実装する-->
    <script type="text/javascript">
        /*
        処理名
            少数点以下の四捨五入、切り上げ、切り捨て処理
        処理概要
            「実行」ボタン押下時、テキストボックスに入力した数値について、
            ラジオボタンで選択した区分で、小数点以下の処理を分ける
                そのまま
                四捨五入
                切り捨て
                切り上げ
        引数
            なし
        戻り値
            なし
        */
        function btn_click_func_number() {
            // div要素を取得する(テキストボックス)
            let input_num_id = document.getElementById('txt_number');

            // 数値に変換
            let input_num = parseFloat(input_num_id.value);

            // div要素を取得する(form要素)
            let input_radiobtn = document.getElementById('number_processing');

            // ラジオボタンの要素を取得(name=num_pattern)
            let num_pattern_name = input_radiobtn.num_pattern;

            // 取得したラジオボタン要素の値(value)を取得
            let num_pattern_value = num_pattern_name.value;

            // div要素を取得する(アウトプット)
            let div_result = document.getElementById('result');

            // 処理区分に応じて処理分岐
            if(num_pattern_value == "normal"){
                // そのまま表示
                div_result.innerHTML = `${input_num}`;
            }else if(num_pattern_value == "round") {
                // 四捨五入
                div_result.innerHTML = `${Math.round(input_num)}`;
            }else if(num_pattern_value == "floor") {
                // 切り捨て
                div_result.innerHTML = `${Math.floor(input_num)}`;
            }else if(num_pattern_value == "ceil") {
                // 切り上げ
                div_result.innerHTML = `${Math.ceil(input_num)}`;
            }

        }

    </script>

    <!-- 入出力設定 -->
    【入力値】
    <br>
    <input type="text" id="txt_number">
    <br>
    <br>

    【小数点以下の処理】
    <br>
    <form id="number_processing">
        <label><input type="radio" name="num_pattern" value="normal" checked>そのまま</label>
        <br>
        <label><input type="radio" name="num_pattern" value="round">四捨五入</label>
        <br>
        <label><input type="radio" name="num_pattern" value="floor">切り捨て</label>
        <br>
        <label><input type="radio" name="num_pattern" value="ceil">切り上げ</label>
    </form>
    <input type="button" value="実行" id="btn_title">
    <br>
    <br>

    【処理結果】
    <div id="result"></div>

</body>
</html>

■実行結果

▼そのまま

・テキストボックスに「3.5」を入力し、「そのまま」を選択し、実行すると「3.5」が表示される。


・テキストボックスに「3.4」を入力し、「そのまま」を選択し、実行すると「3.4」が表示される。

▼四捨五入

・テキストボックスに「3.5」を入力し、「四捨五入」を選択し、実行すると「4」が表示される。


・テキストボックスに「3.4」を入力し、「四捨五入」を選択し、実行すると「3」が表示される。

▼切り捨て

・テキストボックスに「3.5」を入力し、「切り捨て」を選択し、実行すると「3」が表示される。


・テキストボックスに「3.4」を入力し、「切り捨て」を選択し、実行すると「3」が表示される。

▼切り上げ

・テキストボックスに「3.5」を入力し、「切り上げ」を選択し、実行すると「4」が表示される。


・テキストボックスに「3.4」を入力し、「切り上げ」を選択し、実行すると「4」が表示される。

コメント