全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解javascript中对数据格式化的思考

在实际应用场景中,我们常常需将一些数据输出成更加符合人类习惯阅读的格式。

保留小数点后面两位

在一些要求精度没有那么准确的场景下,我们可以直接通过Number.prototype.toFixed()来实现保留小数点两位这样的需求。

var num = 123.45678
console.log(num.toFixed(2)) //123.46

var num2 = 12
console.log(num2.toFixed(2)) //12.00

不过如果恰好,数字是一个整数,那么就会输出12.00这样的格式,我们常常对于后面为00的整数要求直接输出整数即可。因此不妨这样写。

var num = 123.45678
console.log(num.toFixed(2).replace('.00', '')) //123.46

var num2 = 12
console.log(num2.toFixed(2).replace('.00', '')) //12

toFixed()后面直接接着replace()将整数才会出现的.00字符串替换掉即可。

ps: Number.prototype.toFixed返回的是一个字符串

数字为[0-9]的情况下,前置补0

在输出某些数字的时候下,如果是小于10的情况下需要在前面补0,尤其是在输出日期时间的时候。

以前在用Date对象去获取到相关的时间数据的时候去判断是否小于10,如果是就补0。

var date = new Date()
var min = date.getMinutes()
min = min < 10 ? '0' + min : min
console.log(min) //08

后来觉得实在不够优雅,而且代码繁多,就想到用字符串替换的方式。

var date = new Date()
var min = String(date.getMinutes()).replace(/^(\d{1})$/, '0$1')
console.log(min) //08

这样利用正则去匹配到单数字的情况下直接在前面加上0即可,一行代码,更加优雅。

再继续衍生下去,我基本上都是在日期格式化的时候需要做数字替换,何不直接整个字符串替换即可?比如将2017-1-8 12:8替换成2017-01-08 12:08

var date = '2017-1-8 12:8'.replace(/\b\d{1}\b/g, '0$&')
console.log(date)

通过正则去做整个字符串替换,不再针对性的针对某些部分做处理了。 最后给出完整的格式化日期函数示例。

function formatDate (source, format) {
 var date = new Date();
 format = format || 'yyyy-MM-dd hh:mm';
 if (typeof source == 'string') format = source;
 if (typeof source == 'number') date = new Date(source);
 
 let year = date.getFullYear();
 let month = date.getMonth() + 1;
 let day = date.getDate();
 let hour = date.getHours();
 let miniute = date.getMinutes();
 let second = date.getSeconds();
 return format.replace('yyyy', year)
  .replace('MM', month)
  .replace('dd', day)
  .replace('hh', hour)
  .replace('mm', miniute)
  .replace('ss', second)
  .replace(/\b\d{1}\b/g, '0$&');
 return date;
}

上面列举的所有代码,都没有考察对比过执行效率,因为在这些应用场景下,效率是其次问题。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# javascript  # 数据格式化  # javascript格式化数字  # PHP自定义函数格式化json数据示例  # PHP的serialize序列化数据以及JSON格式化数据分析  # 使用js实现数据格式化  # js格式化货币数据实现代码  # js中格式化日期时间型数据函数代码  # 用JavaScript将从数据库中读取出来的日期型格式化为想要的类型。  # 是在  # 两位  # 情况下  # 在前面  # 的是  # 是一个  # 就会  # 去做  # 可以直接  # 在这些  # 上都  # 来实现  # 大家多多  # 才会出现  # 判断是否  # 替换成  # 在实际  # console  # log  # getHours 


相关文章: 如何在搬瓦工VPS快速搭建网站?  如何在云主机快速搭建网站站点?  岳西云建站教程与模板下载_一站式快速建站系统操作指南  css网站制作参考文献有哪些,易聊怎么注册?  建站之星云端配置指南:模板选择与SEO优化一键生成  如何在IIS中新建站点并解决端口绑定冲突?  制作充值网站的软件,做人力招聘为什么要自己交端口钱?  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  内网网站制作软件,内网的网站如何发布到外网?  网站制作壁纸教程视频,电脑壁纸网站?  网页设计网站制作软件,microsoft office哪个可以创建网页?  大学网站设计制作软件有哪些,如何将网站制作成自己app?  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  制作销售网站教学视频,销售网站有哪些?  电商网站制作价格怎么算,网上拍卖流程以及规则?  如何高效搭建专业期货交易平台网站?  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?  电脑免费海报制作网站推荐,招聘海报哪个网站多?  武清网站制作公司,天津武清个人营业执照注销查询系统网站?  如何通过FTP空间快速搭建安全高效网站?  *服务器网站为何频现安全漏洞?  建站之星多图banner生成与模板自定义指南  高端智能建站公司优选:品牌定制与SEO优化一站式服务  建站主机系统SEO优化与智能配置核心关键词操作指南  广平建站公司哪家专业可靠?如何选择?  建站之星24小时客服电话如何获取?  如何在云虚拟主机上快速搭建个人网站?  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  如何在服务器上三步完成建站并提升流量?  清除minerd进程的简单方法  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  如何在云服务器上快速搭建个人网站?  手机网站制作与建设方案,手机网站如何建设?  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  平台云上自主建站:模板化设计与智能工具打造高效网站  广州顶尖建站服务:企业官网建设与SEO优化一体化方案  如何通过cPanel快速搭建网站?  建站之星价格显示格式升级,你的预算足够吗?  宝塔新建站点报错如何解决?  如何在阿里云购买域名并搭建网站?  如何快速搭建支持数据库操作的智能建站平台?  定制建站平台哪家好?企业官网搭建与快速建站方案推荐  C++用Dijkstra(迪杰斯特拉)算法求最短路径  公司网站制作价格怎么算,公司办个官网需要多少钱?  制作公司内部网站有哪些,内网如何建网站?  建站之星如何助力网站排名飙升?揭秘高效技巧  再谈Python中的字符串与字符编码(推荐)  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  深圳网站制作案例,网页的相关名词有哪些? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。