echarts 动态设置y轴单位_Echarts动态设置y轴的最大值,只要一个方法

思路:取出所有数据的最大值,如果跟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;

};

使用方法同上

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值