| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 | import dayjs from "dayjs";/** * 将一个整数转换为分数保留两位小数 * @param {number | string | undefined} num 整数 * @return {number} 分数 */export const formatToFraction = (num) => {  if (typeof num === 'undefined') return 0  const parsedNumber = typeof num === 'string' ? parseFloat(num) : num  return parseFloat((parsedNumber / 100).toFixed(2))}/** * 将一个数转换为 1.00 这样 * 数据呈现的时候使用 * * @param {number | string | undefined} num 整数 * @return {string} 分数 */export const floatToFixed2 = (num) => {  let str = '0.00'  if (typeof num === 'undefined') {    return str  }  const f = formatToFraction(num)  const decimalPart = f.toString().split('.')[1]  const len = decimalPart ? decimalPart.length : 0  switch (len) {    case 0:      str = f.toString() + '.00'      break    case 1:      str = f.toString() + '.0'      break    case 2:      str = f.toString()      break  }  return str}/** * 将一个分数转换为整数 * * @param {number | string | undefined} num 分数 * @return {number} 整数 */export const convertToInteger = (num) => {  if (typeof num === 'undefined') return 0  const parsedNumber = typeof num === 'string' ? parseFloat(num) : num  // TODO 分转元后还有小数则四舍五入  return Math.round(parsedNumber * 100)}/** * 时间日期转换 * @param {dayjs.ConfigType} date 当前时间,new Date() 格式 * @param {string} format 需要转换的时间格式字符串 * @description format 字符串随意,如 `YYYY-mm、YYYY-mm-dd` * @description format 季度:"YYYY-mm-dd HH:MM:SS QQQQ" * @description format 星期:"YYYY-mm-dd HH:MM:SS WWW" * @description format 几周:"YYYY-mm-dd HH:MM:SS ZZZ" * @description format 季度 + 星期 + 几周:"YYYY-mm-dd HH:MM:SS WWW QQQQ ZZZ" * @returns {string} 返回拼接后的时间字符串 */export function formatDate(date, format) {  // 日期不存在,则返回空  if (!date) {    return ''  }  // 日期存在,则进行格式化  if (format === undefined) {    format = 'YYYY-MM-DD HH:mm:ss'  }  return dayjs(date).format(format)}/** * 构造树型结构数据 * * @param {*} data 数据源 * @param {*} id id字段 默认 'id' * @param {*} parentId 父节点字段 默认 'parentId' * @param {*} children 孩子节点字段 默认 'children' * @param {*} rootId 根Id 默认 0 */export function handleTree(data, id = 'id', parentId = 'parentId', children = 'children', rootId = 0) {  // 对源数据深度克隆  const cloneData = JSON.parse(JSON.stringify(data))  // 循环所有项  const treeData = cloneData.filter(father => {    let branchArr = cloneData.filter(child => {      //返回每一项的子级数组      return father[id] === child[parentId]    });    branchArr.length > 0 ? father.children = branchArr : '';    //返回第一层    return father[parentId] === rootId;  });  return treeData !== '' ? treeData : data;}/** * 重置分页对象 * * TODO 非繁人:需要处理其它页面 * * @param pagination 分页对象 */export function resetPagination(pagination) {  pagination.list = [];  pagination.total = 0;  pagination.pageNo = 1;}
 |