FCC(ES6写法) Friendly Date Ranges
把常见的日期格式如:YYYY-MM-DD
转换成一种更易读的格式。
易读格式应该是用月份名称代替月份数字,用序数词代替数字来表示天 (1st
代替 1
)。
包含当前年份和相同月份的时候,makeFriendlyDates(["2017-01-02", "2017-01-05"])
应该返回 ["January 2nd","5th"]。
不包含当前年份,makeFriendlyDates(["2003-08-15", "2009-09-21"])
应该返回 ["August 15th, 2003", "September 21st, 2009"]
。
请考虑清楚所有可能出现的情况,包括传入的日期区间是否合理。对于不合理的日期区间,直接返回 undefined
即可。
思路:
就是几个条件判断一下就行了。写的有点繁琐,有更简便的请留言。
let makeFriendlyDates = arr => { const months = {"01" : "January","02" : "February","03" : "March", "04" : "April","05" : "May", "06" : "June", "07" : "July","08" : "August", "09" : "September","10" : "October", "11" : "November","12" : "December" }; let date1 = arr[0].split("-"); let date2 = arr[1].split("-"); let date = new Date(); let dateChange = day => { if(day[0] === "0"){ day = day.substr(1); if(day === "1") return day + "st"; //01->1st if(day === "2") return day + "nd"; //02->2nd if(day === "3") return day + "rd"; //03->3rd else return day + "th"; } else{ if(day.substr(1,1) === "1" && day.substr(0,1) === "2") return day + "st"; //21->21st if(day.substr(1,1) === "1" && day.substr(0,1) === "3") return day + "st"; //31->31st if(day.substr(1,1) === "2" && day.substr(0,1) === "2") return day + "nd"; //22->22nd if(day.substr(1,1) === "3" && day.substr(0,1) === "2") return day + "rd"; //23->23rd else return day + "th"; } }; let sameYear = (d1, d2) => { if(d2[0] - d1[0] > 1) return false; else{ if(d1[0] === d2[0]) return true; else{ //判断相减为1的时候 if(d2[1] > d1[1]) return false; if(d2[1] < d1[1]) return true; //判断在一年以内返回true else return d2[2] < d1[2] ? true : false; //判断是否在一年以内 } } }; if (sameYear(date1, date2)) { if(date1[0] === date2[0]){ if(date1[1] === date2[1]){ //月份相同 if(date1[2] === date2[2]){ //日期相同 let dateArr = []; dateArr.push(months[date1[1]] + " " + dateChange(date1[2]) + ", " + date1[0]); return dateArr; } else{ let dateArr = []; dateArr.push(months[date1[1]] + " " + dateChange(date1[2])); dateArr.push(dateChange(date2[2])); return dateArr; } } else{ //月份不同 let dateArr = []; dateArr.push(months[date1[1]] + " " + dateChange(date1[2])); dateArr.push(months[date2[1]] + " " + dateChange(date2[2])); return dateArr; } } if(date1[0] == date.getFullYear() - 1){ //开始年份为当前年份 let dateArr = []; dateArr.push(months[date1[1]] + " " + dateChange(date1[2])); dateArr.push(months[date2[1]] + " " + dateChange(date2[2])); return dateArr; } else{ let dateArr = []; dateArr.push(months[date1[1]] + " " + dateChange(date1[2]) + ", " + date1[0]); dateArr.push(months[date2[1]] + " " + dateChange(date2[2])); return dateArr; } } if (date2[0] > date1[0]){ //不同年且d2比d1大时 let dateArr = []; dateArr.push(months[date1[1]] + " " + dateChange(date1[2]) + ", " + date1[0]); dateArr.push(months[date2[1]] + " " + dateChange(date2[2]) + ", " + date2[0]); return dateArr; } } makeFriendlyDates(["2017-02-05", "2017-03-03"]);
如果有不明白的地方请留言,如果有更好更简便更优化的方法请留言,谢谢。
更多内容请访问我的个人博客:Bblog
FCC(ES6写法) Friendly Date Ranges的更多相关文章
- js-FCC算法Friendly Date Ranges
让日期区间更友好! 把常见的日期格式如:YYYY-MM-DD 转换成一种更易读的格式. 易读格式应该是用月份名称代替月份数字,用序数词代替数字来表示天 (1st 代替 1). 记住不要显示那些可以被推 ...
- Friendly Date Ranges 让日期区间更友好
把常见的日期格式如:YYYY-MM-DD 转换成一种更易读的格式. 易读格式应该是用月份名称代替月份数字,用序数词代替数字来表示天 (1st 代替 1). 记住不要显示那些可以被推测出来的信息: 如果 ...
- Friendly Date Ranges
让日期区间更友好! 把常见的日期格式如:YYYY-MM-DD 转换成一种更易读的格式. 易读格式应该是用月份名称代替月份数字,用序数词代替数字来表示天 (1st 代替 1). 记住不要显示那些可以被推 ...
- Friendly Date Ranges-freecodecamp算法题目
Friendly Date Ranges 1.要求 把常见的日期格式如:YYYY-MM-DD 转换成一种更易读的格式. 易读格式应该是用月份名称代替月份数字,用序数词代替数字来表示天 (1st 代替 ...
- React,React Native中的es5和es6写法对照
es6用在React中的写法总结: 在es6还没有完全支持到浏览器的阶段里,已经有很多技术人员开始用es6的写法来超前编程了,因为有转义es6语法的工具帮助下,大家才可大量使用.解析看看es6写法用在 ...
- 6-最基础的服务-es6写法
创建server.js 'use strict'; //http模块 var http = require('http'); //封装的方法 var handlers = require('./han ...
- react-native ES5与ES6写法对照表
转载链接:http://www.ncloud.hk/%E6%8A%80%E6%9C%AF%E5%88%86%E4%BA%AB/react-native-es5-and-es6-writing-tabl ...
- 【转】React Native中ES5 ES6写法对照
很多React Native的初学者都被ES6的问题迷惑:各路大神都建议我们直接学习ES6的语法(class Foo extends React.Component),然而网上搜到的很多教程和例子都是 ...
- JavaScript get set方法 ES5/ES6写法
网上鲜有get和set的方法的实例,在这边再mark一下. get和set我个人理解本身只是一个语法糖,它定义的属性相当于“存储器属性” 为内部属性提供了一个方便习惯的读/写方式 ES5写法 func ...
随机推荐
- php递归实现一维数组转为指定树状结构 --- 省市区处理
### 这两天脑壳痛,一时短路,想不到准备利用递归实现这个需求,最后还是要请教同事,回来自己在实现了一遍,并记录下来 ### 原数据: // { // 广东省: { // 广州市: [ // &quo ...
- cocos2dx 开启控制台
打开 SimulatorWin.cpp 把这句启用: #define SIMULATOR_WITH_CONSOLE_AND_MENU 1 这句本来因为#define隐藏了
- java 数组排序 插入排序法
插入排序法思想:将n个数字分为前面几个是有序数字集合,后面几个为无序集合.当然尚未排序之前,可以将n0 看为有序数集合,N1-Nn-1 看为等待排序的无序集合.从N1开始将无序数一个一个插入到有序数集 ...
- spring MVC 项目 WEB-INF下的jsp不能加载css文件
一.项目目录 二.解决方法(已解决) 1. jsp文件加入 <link href="<c:url value="/css/main.css" />&qu ...
- docker镜像保存及导出(save,export)
前言:有时自己的做好的docker镜像,想将这个docker容器弄到其他服务器上去运行:或者已经运行的容器,将其弄导出,运行到其他地方进行测试 1.查看要要保存的镜像的ID docker image ...
- mysql5.7初始化密码报错 ERROR 1820 (HY000): You must reset your password using ALTER USER statement before
mysql初始化密码常见报错问题1,mysql5.6是密码为空直接进入数据库的,但是mysql5.7就需要初始密码 cat /var/log/mysqld.log | grep password1 2 ...
- sql父子表结构,常用脚本
在实际运用中经常会创建这样的结构表Category(Id, ParentId, Name),特别是用于树形结构时(菜单树,权限树..),这种表设计自然而然地会用到递归,若是在程序中进行递归(虽然在程序 ...
- 深入理解css优先级
为什么要写这篇文章是因为 <style type="text/css"> body h1 { color: green; } html h1 { color: purp ...
- [转]7行Python代码的人脸识别
https://blog.csdn.net/wireless_com/article/details/64120516 随着去年alphago 的震撼表现,AI 再次成为科技公司的宠儿.AI涉及的领域 ...
- linux在线安装mysql
1)下载rpm安装包 wget http://dev.mysql.com/get/mysql57-community-release-el7-8.noarch.rpm;2) 安装mysql源 yum ...