115 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
| 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;
 | ||
| } |