154 lines
4.0 KiB
JavaScript
154 lines
4.0 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 = 'YYYY-MM-DD HH:mm:ss') {
|
||
// 日期不存在,则返回空
|
||
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;
|
||
}
|
||
|
||
/**
|
||
* 将值复制到目标对象,且以目标对象属性为准,例:target: {a:1} source:{a:2,b:3} 结果为:{a:2}
|
||
* @param target 目标对象
|
||
* @param source 源对象
|
||
*/
|
||
export const copyValueToTarget = (target, source) => {
|
||
const newObj = Object.assign({}, target, source);
|
||
// 删除多余属性
|
||
Object.keys(newObj).forEach((key) => {
|
||
// 如果不是target中的属性则删除
|
||
if (Object.keys(target).indexOf(key) === -1) {
|
||
delete newObj[key];
|
||
}
|
||
});
|
||
// 更新目标对象值
|
||
Object.assign(target, newObj);
|
||
};
|
||
|
||
/**
|
||
* 解析 JSON 字符串
|
||
*
|
||
* @param str
|
||
*/
|
||
export function jsonParse(str) {
|
||
try {
|
||
return JSON.parse(str);
|
||
} catch (e) {
|
||
console.error(`str[${str}] 不是一个 JSON 字符串`);
|
||
return '';
|
||
}
|
||
}
|