思路:取出所有数据的最大值,如果跟10作比较,比10小,返回10
如果比10大,返回比最大值大的数字,而这个数刚好是10的倍数,这样柱状图比较美观。
下面中的maxValue 为最大值的限制,可随意更改。
方法中传入数组即可,嵌套很深的数组都可以取出最大值
TypeScript
// 设置y轴最大值
const setYAxisMaxVal = (arrayF: number[]): number => {
// 扁平化n维数组方法,与Array.flat()相同
const flatten = (arr: any) => {
while (arr.some((item: any) => Array.isArray(item))) {
arr = [].concat(...arr);
}
return arr;
};
// 计算y轴最大值并返回
const returnMaxValue = (array: number[], referMax: number): number => {
try {
// flat和flatMap方法为ES2019(ES10)方法,目前还未在所有浏览器完全兼容,所以使用trycatch
if (Math.max(...array.flat(Infinity)) > referMax) {
referMax = (referMax - (Math.max(...array.flat(Infinity)) % referMax)) + Math.max(...array.flat(Infinity));
}
return referMax;
} catch (error) {
// 如果客户端不支持flat,则使用上面自己写的flatten来扁平化数组
if (Math.max(...flatten(array)) > referMax) {
referMax = (referMax - (Math.max(...flatten(array)) % referMax)) + Math.max(...flatten(array));
}
return referMax;
}
};
let maxValue: number = 10;
maxValue = returnMaxValue(arrayF, maxValue);
return maxValue;
};
使用
const arr1 = [1, 2, 3, 5, 8]
const arr2 = [11, 1, 8, 5, 8]
const arr3 = [18, 11, 18, 5, 28]
console.log(setYAxisMaxVal([arr1, arr2, arr3])) // 30
或者是这样
const arr1 = [1, 2, 3, 5, 8]
const arr2 = [11, 1, 8, 5, 8]
const arr3 = [18, 11, 18, 5, 28]
const arr4 = [18, 11, 18, 5, 28, [88, 102]]
console.log(setYAxisMaxVal([arr1, arr2, arr3, arr4])) // 110
普通的js环境
const setYAxisMaxVal = (arrayF) => {
const flatten = (arr) => {
while (arr.some((item) => Array.isArray(item))) {
arr = [].concat(...arr);
}
return arr;
};
const returnMaxValue = (array, referMax) => {
try {
if (Math.max(...array.flat(Infinity)) > referMax) {
referMax = (referMax - (Math.max(...array.flat(Infinity)) % referMax)) + Math.max(...array.flat(Infinity));
}
return referMax;
} catch (error) {
if (Math.max(...flatten(array)) > referMax) {
referMax = (referMax - (Math.max(...flatten(array)) % referMax)) + Math.max(...flatten(array));
}
return referMax;
}
};
let maxValue = 10;
maxValue = returnMaxValue(arrayF, maxValue);
return maxValue;
};
使用方法同上
网友评论