js 加算、減算、乗算、除算の正確な計算方法のサンプルコード

js 加算、減算、乗算、除算の正確な計算方法のサンプルコード

序文

コンピュータの数値は浮動小数点であるため、計算プロセス中に取得されるデータは通常正確ではなく、そのためいくつかの配列操作を行うのは面倒です。ここでは、正確な計算を行う方法を記述します。

1つ目は加算です(ここでは2つのデータの追加を例に挙げます)

関数 add(arg1, arg2) {

	 arg1 = arg1.toString(), arg2 = arg2.toString(); // 入力データを文字列に変換します var arg1Arr = arg1.split("."), // 小数点から小数データを分割します arg2Arr = arg2.split("."),
   d1 = arg1Arr.length == 2 ? arg1Arr[1] : "", // 最初の数値の小数点の長さを取得します d2 = arg2Arr.length == 2 ? arg2Arr[1] : ""; // 2 番目の数値の小数点の長さを取得します var maxLen = Math.max(d1.length, d2.length); // 小数点の長さの大きい方の値を取得します var m = Math.pow(10, maxLen); // これは小数点の長さの 10 の累乗を表します。つまり、小数点の長さが 2 の場合、m の値は 100 です。小数点の長さが 3 の場合、m の値は 1000 です。わからない場合は、自分で API を調べてください
  var result = Number(((arg1 * m + arg2 * m) / m).toFixed(maxLen)); // 小数を整数に変換して加算し、乗算された 2 つの数値の倍数を削除して小数点を削除します。var d = arguments[2]; // ユーザーは、保持する小数点の長さを定義するために 3 番目のパラメーターを渡すかどうかを決定できます。return typeof d === "number" ? Number((result).toFixed(d)) : result;
}

加算(12.123, 12)

次に減算を行います(減算は実際には配列に別の数の負数を加算するものなので、ロジックは加算と同じです)

関数sun(arg1, arg2) {
add(arg1, -arg2) を返します
}

次は掛け算です

関数mul(arg1, arg2) {
var r1 = arg1.toString(), // 受信したデータを文字列に変換します r2 = arg2.toString(),
m、結果値、d = 引数[2];
m = (r1.split(".")[1] ? r1.split(".")[1].length : 0) + (r2.split(".")[1] ? r2.split(".")[1].length : 0); // 2 つの数値の小数点以下の合計を取得します // 積のアルゴリズムは、小数点を削除し、整数の乗算を実行してから、10 の累乗をすべて削除します resultVal = Number(r1.replace(".", "")) * Number(r2.replace(".", "")) / Math.pow(10, m);

戻り値の型は d !== "number" ですか? Number(resultVal) : Number(resultVal.toFixed(parseInt(d)));
}

最後に、引き算(割り算と掛け算は逆のプロセスなので、詳しく説明しません)

関数div(arg1, arg2) {
     var r1 = arg1.toString(),
      r2 = arg2.toString(),
      m、結果値、d = 引数[2];
     m = (r2.split(".")[1] ? r2.split(".")[1].length : 0) - (r1.split(".")[1] ? r1.split(".")[1].length : 0);
     resultVal = Number(r1.replace(".", "")) / Number(r2.replace(".", "")) * Math.pow(10, m);
     戻り値の型は d !== "number" ですか? Number(resultVal) : Number(resultVal.toFixed(parseInt(d)));
    }

要約する

js での加算、減算、乗算、除算の正確な計算方法についての記事はこれで終わりです。js での加算、減算、乗算、除算の正確な計算に関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。皆様が今後も 123WORDPRESS.COM を応援してくれることを願っています。

以下もご興味があるかもしれません:
  • 小数の加算、減算、乗算、除算における精度の低下に対する JavaScript ソリューション
  • HTML+JS は、シンプルな計算機コード (加算、減算、乗算、除算) を実装します。
  • js の加算、減算、乗算、除算における精度低下の問題の解決
  • jsの加算、減算、乗算、除算の正確な計算の詳細な説明
  • JS で実装された加算、減算、乗算、除算の計算機の例
  • js 正確な加算、減算、乗算、除算の例
  • JavaScript の加算、減算、乗算、除算の簡単な例
  • 超シンプルな JS 計算機の例の説明 (加算、減算、乗算、除算の実装)

<<:  Node.js における非同期プログラミングの知識ポイントの詳細な説明

>>:  JavaScript/TypeScript で同時リクエスト制御を実装するためのサンプルコード

推薦する

Vueウォッチの監視方法の概要

目次1. Vueにおけるwatchの役割はその名の通り、監視の役割です。 2. このオブジェクトのプ...

MySQL スライディングオーダー問題の原理と解決の例分析

この記事では、例を使用して、MySQL スライディング順序問題の原理と解決方法を説明します。ご参考ま...

MySQLの基本を素早く学ぶ

目次SQLを理解するSELECTを理解するエイリアス定数をクエリし、固定定数列を追加します。重複行を...

MySQLのロック機構に関する最も包括的な説明

目次序文グローバルロック完全なデータベース論理バックアップFTWRL と set global re...

PHP+nginx サービス 500 502 エラーのトラブルシューティングのアイデアの詳細な説明

概要オンラインサービスへのアクセス中に 500 または 502 エラーが発生した場合、緊急処理とトラ...

CUDA10.0 のインストールと Ubuntu での問題

Tensorflow バージョンと Cuda および CUDNN の対応: https://tens...

CSS3は赤い封筒を振る効果を実現します

赤い封筒の揺れ効果を実現するには要件があります。これまでやったことがないので、記録しておきます。ヘヘ...

Ubuntu 18.0.4 は mysql をインストールし、エラー 1698 (28000): ユーザー ''root''@''localhost'' のアクセスが拒否されましたを解決します

序文最近 Linux を学び、その後 Win から Ubuntu に変更しました。以前インストールし...

Js の継承とプロトタイプチェーンを理解するのに役立つ記事

目次継承とプロトタイプチェーン継承されたプロパティ継承されたメソッドJavaScript でのプロト...

Ubuntu 18.04 Server バージョンのインストールと使用方法 (画像とテキスト)

1 システムのインストール手順OSバージョン:1804イメージのダウンロード: http://cd...

MySQLの整数および文字列インデックスの無効化または暗黙的な変換に関する簡単な説明

目次問題の概要問題の再現問題の拡大結論は問題の概要今日、仕事中に、DBA が突然、SQL に暗黙的な...

IE6 で JS エラーが発生し、CSS が適用されない HTML エンコードの問題の解決策

テストでは、ページ定義がutf-8でエンコードされている場合、 js ファイルに中国語などのマルチバ...

Linux でリモート MySQL データベースを手動で展開する方法の詳細な説明

1. mysql をインストールします。次のコマンドを実行して、YUM ソースを更新します。 rpm...

HTML の doctype とエンコーディングに関する簡単な説明

文書タイプDoctype は、指示を解析するためにどのバージョンの HTML を使用するかをブラウザ...

Windows Server 2016 でサービスを展開する方法 (グラフィック チュートリアル)

導入インストールするシステムの数が多い場合、USB フラッシュ ドライブまたは CD を使用した手動...