Maison > interface Web > js tutoriel > Quelles sont les fonctions js qui conservent deux décimales ?

Quelles sont les fonctions js qui conservent deux décimales ?

coldplay.xixi
Libérer: 2020-09-28 09:27:58
original
27047 Les gens l'ont consulté

Les fonctions JS qui conservent deux décimales incluent : 1. La fonction [toFixed()] ; 2. La fonction [Math.floor()] n'arrondit pas, mais arrondit à l'inférieur ; . Arrondissez à 2 décimales ; 5. Flottez à 2 décimales.

Quelles sont les fonctions js qui conservent deux décimales ?

Les fonctions JS qui conservent deux décimales sont :

1. 🎜>1. Méthode ToFixed()

Veuillez noter que deux décimales sont conservées et que les données de type numérique sont transformées en type de chaîne

// 1.四舍五入
     var num =2.446242342;  
    num = num.toFixed(2); 
   console.log(num); //2.45
  console.log(typeof num); // string
Copier après la connexion

2. n'arrondissez pas, arrondissez à l'inférieur

Remarque, ne changez pas le type de données

// 2.不四舍五入 向下取整
    num = Math.floor(num * 100) / 100;
     console.log(num); //2.44
    console.log(typeof num); // number
Copier après la connexion

3 Correspondance de chaîne

Remarque, convertissez d'abord les données en chaîne, et enfin Convertissez. au type numérique

// 3.不四舍五入 字符串匹配再转换
   num = Number(num.toString().match(/^\d+(?:\.\d{0,2})?/));
    console.log(num); //2.44
    console.log(typeof num); // number
Copier après la connexion

4. Arrondir à 2 décimales (si la deuxième décimale est 0, conserver une décimale)

Notez que le type de données reste inchangé

//4.四舍五入保留2位小数(若第二位小数为0,则保留一位小数)
        function keepTwoDecimal(num) {
             var result = parseFloat(num);
             if (isNaN(result)) {
                 alert('传递参数错误,请检查!');
                 return false;
             }
             result = Math.round(num * 100) / 100;
             return result;
        };
         keepTwoDecimal(num);
         console.log(num); //2.44
         console.log(typeof num); //number
Copier après la connexion

5. Arrondissez pour conserver 2 décimales (s'il n'y a pas assez de chiffres, utilisez 0 comme substitut)

Notez que le type de données change en type chaîne

//5.四舍五入保留2位小数(不够位数,则用0替补)
        function keepTwoDecimalFull(num) {
             var result = parseFloat(num);
             if (isNaN(result)) {
                 alert('传递参数错误,请检查!');
                 return false;
             }
             result = Math.round(num * 100) / 100;
             var s_x = result.toString(); //将数字转换为字符串
             var pos_decimal = s_x.indexOf('.'); //小数点的索引值
             // 当整数时,pos_decimal=-1 自动补0
             if (pos_decimal < 0) {
                 pos_decimal = s_x.length;
                 s_x += &#39;.&#39;;
             }
             // 当数字的长度< 小数点索引+2时,补0
             while (s_x.length <= pos_decimal + 2) {
                 s_x += &#39;0&#39;;
             }
             return s_x;
        }
         console.log(keepTwoDecimalFull(120.5)); //120.50
         console.log(typeof keepTwoDecimalFull(120.5)); //string
         console.log(keepTwoDecimalFull(2.446242342)); //2.45
         console.log(typeof keepTwoDecimalFull(2.446242342)); //string
Copier après la connexion

2. Flottant les nombres à virgule conservent deux décimales Places décimales

1 Arrondissez le nombre à virgule flottante à 2 décimales

Notez que le type de données reste inchangé

//浮点数保留两位小数
          //1.功能:将浮点数四舍五入,取小数点后2位
          function toDecimal(x) {
           var f = parseFloat(x);
           if (isNaN(f)) {
            return;
           }
           f = Math.round(x*100)/100;
           return f;
          }
          console.log(toDecimal(3.1465926)); // 3.15
          console.log(typeof toDecimal(3.1415926)); //number
Copier après la connexion

2. Forcer la conservation de 2 décimales. Par exemple : 2, 00 sera ajouté après 2. C'est-à-dire 2,00

Notez que le type de données passe au type de chaîne

//2.强制保留2位小数,如:2,会在2后面补上00.即2.00
          function toDecimal2(x) {
           var f = parseFloat(x);
           if (isNaN(f)) {
            return false;
           }
           var f = Math.round(x*100)/100;
           var s = f.toString();
           var rs = s.indexOf(&#39;.&#39;);
           if (rs < 0) {
            rs = s.length;
            s += &#39;.&#39;;
           }
           while (s.length <= rs + 2) {
            s += &#39;0&#39;;
           }
           return s;
          }
          console.log(toDecimal2(3.1)); // 3.10
          console.log(typeof toDecimal2(3.1415926)); //string
Copier après la connexion

Deux décimales. les emplacements sont conservés et les nombres à virgule flottante ne sont pas arrondis s'il n'y a pas assez de chiffres 0

Notez que le type de données reste inchangé

// 3.保留两位小数 浮点数四舍五入 位数不够 不补0
          function fomatFloat(src,pos){
            return Math.round(src*Math.pow(10, pos))/Math.pow(10, pos);
          }
           console.log(fomatFloat(3.12645,2)); // 3.13
          console.log(typeof fomatFloat(3.1415926)); //numbe
Copier après la connexion

Autres recommandations d'apprentissage gratuites associées :

Tutoriel vidéo javascript

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal