index.js 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. import dayjs from 'dayjs';
  2. /**
  3. * 将一个整数转换为分数保留两位小数
  4. * @param {number | string | undefined} num 整数
  5. * @return {number} 分数
  6. */
  7. export const formatToFraction = (num) => {
  8. if (typeof num === 'undefined') return 0;
  9. const parsedNumber = typeof num === 'string' ? parseFloat(num) : num;
  10. return parseFloat((parsedNumber / 100).toFixed(2));
  11. };
  12. /**
  13. * 将一个数转换为 1.00 这样
  14. * 数据呈现的时候使用
  15. *
  16. * @param {number | string | undefined} num 整数
  17. * @return {string} 分数
  18. */
  19. export const floatToFixed2 = (num) => {
  20. let str = '0.00';
  21. if (typeof num === 'undefined') {
  22. return str;
  23. }
  24. const f = formatToFraction(num);
  25. const decimalPart = f.toString().split('.')[1];
  26. const len = decimalPart ? decimalPart.length : 0;
  27. switch (len) {
  28. case 0:
  29. str = f.toString() + '.00';
  30. break;
  31. case 1:
  32. str = f.toString() + '.0';
  33. break;
  34. case 2:
  35. str = f.toString();
  36. break;
  37. }
  38. return str;
  39. };
  40. /**
  41. * 将一个分数转换为整数
  42. *
  43. * @param {number | string | undefined} num 分数
  44. * @return {number} 整数
  45. */
  46. export const convertToInteger = (num) => {
  47. if (typeof num === 'undefined') return 0;
  48. const parsedNumber = typeof num === 'string' ? parseFloat(num) : num;
  49. // TODO 分转元后还有小数则四舍五入
  50. return Math.round(parsedNumber * 100);
  51. };
  52. /**
  53. * 时间日期转换
  54. * @param {dayjs.ConfigType} date 当前时间,new Date() 格式
  55. * @param {string} format 需要转换的时间格式字符串
  56. * @description format 字符串随意,如 `YYYY-mm、YYYY-mm-dd`
  57. * @description format 季度:"YYYY-mm-dd HH:MM:SS QQQQ"
  58. * @description format 星期:"YYYY-mm-dd HH:MM:SS WWW"
  59. * @description format 几周:"YYYY-mm-dd HH:MM:SS ZZZ"
  60. * @description format 季度 + 星期 + 几周:"YYYY-mm-dd HH:MM:SS WWW QQQQ ZZZ"
  61. * @returns {string} 返回拼接后的时间字符串
  62. */
  63. export function formatDate(date, format = 'YYYY-MM-DD HH:mm:ss') {
  64. // 日期不存在,则返回空
  65. if (!date) {
  66. return '';
  67. }
  68. // 日期存在,则进行格式化
  69. if (format === undefined) {
  70. format = 'YYYY-MM-DD HH:mm:ss';
  71. }
  72. return dayjs(date).format(format);
  73. }
  74. /**
  75. * 构造树型结构数据
  76. *
  77. * @param {*} data 数据源
  78. * @param {*} id id字段 默认 'id'
  79. * @param {*} parentId 父节点字段 默认 'parentId'
  80. * @param {*} children 孩子节点字段 默认 'children'
  81. * @param {*} rootId 根Id 默认 0
  82. */
  83. export function handleTree(
  84. data,
  85. id = 'id',
  86. parentId = 'parentId',
  87. children = 'children',
  88. rootId = 0,
  89. ) {
  90. // 对源数据深度克隆
  91. const cloneData = JSON.parse(JSON.stringify(data));
  92. // 循环所有项
  93. const treeData = cloneData.filter((father) => {
  94. let branchArr = cloneData.filter((child) => {
  95. //返回每一项的子级数组
  96. return father[id] === child[parentId];
  97. });
  98. branchArr.length > 0 ? (father.children = branchArr) : '';
  99. //返回第一层
  100. return father[parentId] === rootId;
  101. });
  102. return treeData !== '' ? treeData : data;
  103. }
  104. /**
  105. * 重置分页对象
  106. *
  107. * TODO 芋艿:需要处理其它页面
  108. *
  109. * @param pagination 分页对象
  110. */
  111. export function resetPagination(pagination) {
  112. pagination.list = [];
  113. pagination.total = 0;
  114. pagination.pageNo = 1;
  115. }
  116. /**
  117. * 将值复制到目标对象,且以目标对象属性为准,例:target: {a:1} source:{a:2,b:3} 结果为:{a:2}
  118. * @param target 目标对象
  119. * @param source 源对象
  120. */
  121. export const copyValueToTarget = (target, source) => {
  122. const newObj = Object.assign({}, target, source);
  123. // 删除多余属性
  124. Object.keys(newObj).forEach((key) => {
  125. // 如果不是target中的属性则删除
  126. if (Object.keys(target).indexOf(key) === -1) {
  127. delete newObj[key];
  128. }
  129. });
  130. // 更新目标对象值
  131. Object.assign(target, newObj);
  132. };
  133. /**
  134. * 解析 JSON 字符串
  135. *
  136. * @param str
  137. */
  138. export function jsonParse(str) {
  139. try {
  140. return JSON.parse(str);
  141. } catch (e) {
  142. console.error(`str[${str}] 不是一个 JSON 字符串`);
  143. return '';
  144. }
  145. }