• 5种方式将数字转成千分位


    曾经是一个经典面试题哦,大家看看自己会不会

    1、利用正则的零宽度正预测先行断言(?=exp),名字有点难记,意思是它断言自身出现的位置的后面能匹配表达式exp,对此概念还不明白的可以戳这里,这里不做过多解释。数字千分位的特点是,第一个逗号后面数字的个数是3的倍数,正则:/(d{3})+$/;第一个逗号前最多可以有1至3个数字,正则:/d{1,3}/。加起来就是/d{1,3}(d{3})+$/,分隔符要从前往后加,就要将前面的数字“87”替换成“87,”,为什么是87不是874?因为874后面只剩下5位数字,在632后加一个分隔符后,将只剩下97,不符合千分位要求,所以第一个分隔符后面的数字位数必须是3的倍数。要匹配数字87,又要保证87后面数字位数是3的倍数,并且要将匹配的87替换成“87,”,就要用到(?=exp),这里先定义一个变量var str = "87463297";

    // 零宽断言
    console.info( str.replace(/d{1,3}(?=(d{3})+$)/g,function(s){
        return s+','
    }) )


    2、利用正则的子项来替换,跟第1种方法类似。
    // 子项
    console.info( str.replace(/(d{1,3})(?=(d{3})+$)/g,function($1){
        return $1=$1+','
    }) )


    3、先将字符串转成数组,利用reverse反转数组后每3个数字后添加一个分隔符“,”,到字符串末尾除外,之后转回字符串。
    // 利用字符串和数组方法
    console.info( str.split("").reverse().join("").replace(/(d{3})+?/g,function(s){
        return s+",";
    }).replace(/,$/,"").split("").reverse().join("") )


    4、利用while循环拼接字符串每隔3个数字加一个分隔符,首尾不加
    // 利用循环拼接字符串每隔3个加一个分隔符
    var result="",
        index = 0,
        len = str.length-1;
    while(len>=0) {
        index%3===0&&index!==0 ? result+=","+str[len] : result+=str[len];
        len--;
        index++;
    };
    result=result.split("").reverse().join("");
    console.info(result);

    5、利用while循环在数组里push分隔符,首尾不加

    // 利用while循环在数组里push分隔符
    var result="",
        index = 0,
        len = str.length,
        arr = str.split("");
     
    while(len-index>0){
        len>=index&&len-index!==len && arr.splice(len-index,0,",");
        index+=3;
     
    };
    console.log(arr.join(""));

    注:第1种方法是最简洁的,性能也是最好的,推荐使用。


  • 相关阅读:
    JS 关于 URL 的编码或解码方法
    PHP 获取上一个页面的url
    踩坑 Uncaught RangeError: Maximum call stack size exceeded
    Wordpress 数据库查询错误 Call to a member function get_results() on null
    Chrome autocomplete="off"无效
    js 遍历对象属性(for in、Object.keys、Object.getOwnProperty) 以及高效地输出 js 数组
    PHP PDO fetch() 详解
    Wordpress 自定义文章类型添加 Categoried、Tags
    Mac: mac git 的安装 及实现自动补全
    Uncaught TypeError: Cannot read property of undefined In JavaScript
  • 原文地址:https://www.cnblogs.com/hongsusu/p/9066194.html
Copyright © 2020-2023  润新知