做手机端页面我们常常遇到数字,而在Safari浏览器下这些数字会默认显示电话号码,于是我们就用到了补坑的方法加入<meta>标签:

<meta name="format-detection" content="telephone=no">
这个标签的意义在于将数字不被看成电话号码,于是就万事大吉了O(∩_∩)O,但是如果是一个订餐电话,那么在加入这个标签之后,订餐电话就变成了数字,就不能直接拨号了于是乎我们想到了用千位符老表示数字从而区分电话号码和数字 千位符

在西方,在表示很大的数字的时候,会以每3位为一个间隔进行分隔,分隔的符号就是英文逗号,由于中文里面,第3位是“千”,因此,数字中的这个“逗号”也被称为“千位分隔符”。

之所以会以每3位进行分隔,是英文的读数有关的,举个例子:英语的987,654,321读法是: nine hundred and eighty-seven billion six hundred and fifty-four thousand three hundred and twenty-one。

其关键的数值单位,如billionthousand正好就是千分分隔符的位置。可见这种分隔是和西方数值阅读方法相辅相成的。

但是对于中文用户而言,这种风格反而是一种尴尬。我们的大数值单位主要就是“万”和“亿”,如果按照这种标准进行分割的话,应该是每4位进行分隔。所以,当我们一开始看到3位分隔的数字的时候,一定会奇怪这分隔的方式有些不按套路。

那有没有解决的办法呢;

办法一:

方法一:使用正则表达式


语法如下:


String(Number).replace(/(\d)(?=(\d{3})+$)/g, "$1,");

举例:


String(123456789).replace(/(\d)(?=(\d{3})+$)/g, "$1,");
办法二:

方法二:使用toLocaleString()方法


语法如下:


Number.toLocaleString('en-US');

举例:


(123456789).toLocaleString('en-US');

结果是:123,456,789


对于中文场景下,toLocaleString('en-US')中的'en-US'理论上是可以缺省的,也就是直接(123456789).toLocaleString()也是可以得到123,456,789。但是如果你的产品可能海外用户使用,则保险起见,还是保留'en-US'


另外,对于IE edge之前的版本,Number.toLocaleString()会自动补上两位小数,如果是不需要的,需要自己额外过滤掉。


最新文章

  1. 用SVN check out项目后第三方库丢失
  2. SqlServer StringToTable性能测试
  3. Android Volley 框架的使用(一)
  4. JavaScript基础笔记一
  5. Android 之 悬浮窗
  6. sqlite3---代码操作
  7. select选项改变时获取选中的option的值
  8. 一个解析url参数方法
  9. CentOS_6.5_x64:VNC安装配置
  10. jvm内存增长问题排查
  11. JAVA 程序发布引发性能抖动
  12. iOS学习之Runtime(一)
  13. [SimplePlayer] 8. 音视频同步
  14. COGS 2392 2393 2395 有标号的二分图计数
  15. Swagger入门
  16. vue自定义公共组件components||在vue中,解决修改后的数据不能渲染到dom上的bug
  17. Spring MVC异常统一处理的三种方式
  18. 【BZOJ1434】[ZJOI2009]染色游戏(博弈论)
  19. 【BZOJ】4767: 两双手【组合数学】【容斥】【DP】
  20. ORA-00918:未明确定义列解决

热门文章

  1. Hibernate注解-类级别注解
  2. 通过css控制超链接不显示下划线
  3. postgresql如何维护WAL日志/归档日志
  4. 格式化JSON字符串
  5. base64随机字符混淆加密、解密-美拍视频地址解密,反推加密算法
  6. Scala中柯里化函数
  7. 基于FPGA的Sobel边缘检测的实现
  8. 深入剖析ConcurrentHashMap 一
  9. [置顶] 基于FPGA的VGA简易显存设计&NIOS ii软核接入
  10. .net core的在初始化数据的拦截处理