dateTimePicker.js 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. function withData(param) {
  2. return param < 10 ? '0' + param : '' + param;
  3. }
  4. function getLoopArray(start, end) {
  5. var start = start || 0;
  6. var end = end || 1;
  7. var array = [];
  8. for (var i = start; i <= end; i++) {
  9. array.push(withData(i));
  10. }
  11. return array;
  12. }
  13. function getMonthDay(year, month) {
  14. var flag = year % 400 == 0 || (year % 4 == 0 && year % 100 != 0),
  15. array = null;
  16. switch (month) {
  17. case '01':
  18. case '03':
  19. case '05':
  20. case '07':
  21. case '08':
  22. case '10':
  23. case '12':
  24. array = getLoopArray(1, 31)
  25. break;
  26. case '04':
  27. case '06':
  28. case '09':
  29. case '11':
  30. array = getLoopArray(1, 30)
  31. break;
  32. case '02':
  33. array = flag ? getLoopArray(1, 29) : getLoopArray(1, 28)
  34. break;
  35. default:
  36. array = '月份格式不正确,请重新输入!'
  37. }
  38. return array;
  39. }
  40. function getNewDateArry() {
  41. // 当前时间的处理 年月日时分秒
  42. var newDate = new Date();
  43. var year = withData(newDate.getFullYear()),
  44. mont = withData(newDate.getMonth() + 1),
  45. date = withData(newDate.getDate()),
  46. hour = withData(newDate.getHours()),
  47. minu = withData(newDate.getMinutes());
  48. seco = withData(newDate.getSeconds());
  49. return [year, mont, date, hour, minu, seco];
  50. }
  51. function dateTimePicker(startYear, endYear, date) {
  52. // 返回默认显示的数组和联动数组的声明
  53. var dateTime = [],
  54. dateTimeArray = [
  55. [],
  56. [],
  57. [],
  58. [],
  59. [],
  60. []
  61. ];
  62. var start = startYear || 1978;
  63. var end = endYear || 2100;
  64. //处理传过来的字符串转化为数组
  65. let dataArr = date.split(" ")[0].split('/')
  66. let time = date.split(" ")[1].split(':')
  67. // 默认开始显示数据 如果把自定义值传过来的话就使用自定义时间 否则用当前时间 ...dataArr数组解构
  68. var defaultDate = date ? [...dataArr, ...time] : getNewDateArry();
  69. // 处理联动列表数据
  70. /*年月日 时分秒*/
  71. dateTimeArray[0] = getLoopArray(start, end);
  72. dateTimeArray[1] = getLoopArray(1, 12);
  73. dateTimeArray[2] = getMonthDay(defaultDate[0], defaultDate[1]);
  74. dateTimeArray[3] = getLoopArray(0, 23);
  75. dateTimeArray[4] = getLoopArray(0, 59);
  76. dateTimeArray[5] = getLoopArray(0, 59);
  77. //遍历dateTimeArray数组
  78. dateTimeArray.forEach((current, index) => {
  79. //匹配defaultDate[index]值在current数组中的位置
  80. dateTime.push(current.indexOf(defaultDate[index]))
  81. });
  82. return {
  83. dateTimeArray: dateTimeArray,
  84. dateTime: dateTime
  85. }
  86. }
  87. module.exports = {
  88. dateTimePicker: dateTimePicker,
  89. getMonthDay: getMonthDay
  90. }