Rumah >hujung hadapan web >tutorial js >Bagaimana untuk Memotong Nombor ke Dua Tempat Perpuluhan Tanpa Pembundaran dalam JavaScript?

Bagaimana untuk Memotong Nombor ke Dua Tempat Perpuluhan Tanpa Pembundaran dalam JavaScript?

Barbara Streisand
Barbara Streisandasal
2024-11-10 05:44:021034semak imbas

How to Truncate Numbers to Two Decimal Places Without Rounding in JavaScript?

Memotong Nombor kepada Dua Tempat Perpuluhan Tanpa Membundarkan

Apabila bekerja dengan nombor dalam JavaScript, selalunya perlu memaparkannya dengan nombor tertentu tempat perpuluhan. Kaedah toFixed() boleh digunakan untuk membundarkan nombor kepada nombor tempat perpuluhan yang ditentukan, tetapi bagaimana jika anda perlu memotong nombor tanpa membundarkan?

Pertimbangkan contoh berikut:

var num = parseFloat(15.7784514);
document.write(num.toFixed(1) + "<br />");
document.write(num.toFixed(2) + "<br />");
document.write(num.toFixed(3) + "<br />");
document.write(num.toFixed(10));

Kod ini menghasilkan output berikut:

15.8
15.78
15.778
15.7784514000

Seperti yang anda lihat, kaedah toFixed() membundarkan nombor kepada bilangan tempat perpuluhan yang ditentukan. Untuk memotong nombor sebaliknya, kita boleh menukarnya menjadi rentetan dan menggunakan ungkapan biasa untuk memadankan nombor sehingga tempat perpuluhan kedua:

function calc(theform) {
  var num = theform.original.value, rounded = theform.rounded
  var with2Decimals = num.toString().match(/^-?\d+(?:\.\d{0,2})?/)[0]
  rounded.value = with2Decimals
}

Kod ini menukar nombor asal kepada rentetan, dan kemudian menggunakan ungkapan biasa ^-?d (?:.d{0,2})? untuk memadankan nombor sehingga tempat perpuluhan kedua. Rentetan yang terhasil kemudiannya diberikan kepada elemen bulat dalam bentuk.

Pendekatan ini akan memotong nombor kepada dua tempat perpuluhan tanpa pembundaran. Contohnya, jika nombor asal ialah 15.7784514, nilai yang dipotong ialah 15.77.

Atas ialah kandungan terperinci Bagaimana untuk Memotong Nombor ke Dua Tempat Perpuluhan Tanpa Pembundaran dalam JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn