来聊聊Echarts的基于X轴缩放和基于Y轴缩放,以及切换之后状态保持的问题

Echarts支持基于轴线缩放的,在slider模式中应用的很成熟,但体验和样式并不能得到来自设计和产品的认可,他们想要的样式和功能是长这样的

那就需要大量自定义的功能,首先你的在toolbox.feature里自定义x轴y轴以及还原功能icon

这些图标可以自行去iconfont上面找,我是直接下载为png格式,存到项目的文件夹中,再引入到组件中的方式

markdown 复制代码
toolbox: {

  feature: {

    myXAxisX: {

       show: true,

       title: '',

       icon: computed(() => {

          return 'image://' + xIcon_default;

       }),

       onclick: function (val) {

           console.log('点击x轴缩放');

      });

    },

 },

其中xIcon_default的引入 import xIcon_default from '@/assets/images/zuoyoujiantou.png'; 同理,y轴和还原icon也参照这样的设置方式 这里还需要设置dataZoom,既然是只允许某一个轴线的缩放,比如是基于x轴缩放,而y轴不允许缩放

markdown 复制代码
dataZoom: [

    {

    type: 'inside',

    xAxisIndex: 0,

    filterMode: 'none',

    start: 0,

    end: 100,

    },

    {

    type: 'inside',

    yAxisIndex: 'none',

    filterMode: 'none',

    start: 0,

    end: 100,

    },

],

缩放的状态你需要去记录下来

csharp 复制代码
myChart.on('dataZoom', function (params) {

    const { batch } = params;

    console.log(batch)

});

获取的batch对应start和end存到dataZoom对应的轴线的start和end中 x轴是dataZoom[0] y 轴是dataZoom[1], 到了这一步如果不切换的情况下,x轴的缩放是没问题的了,那么切换到y轴呢 要把dataZoom[0].xAxisIndex改为none dataZoom[1].yAxisIndex改为0 这样就可以实现y轴的缩放了,但会有一个问题,就是x轴缩放的状态,在切换到y轴时并不能保持,就需要手动去设置,把x轴缩放的状态batch值的start和end赋值给xAxis.max和xAxis.min 这样就可以实现切换轴线缩放,状态的无缝衔接了

相关推荐
Hilaku11 分钟前
AI 生成的代码都是一坨屎?聊聊怎么给 Agent 制定工程约束
前端·javascript·ai编程
吴声子夜歌16 分钟前
Vue3——使用Vue Router实现路由
前端·javascript·vue.js·vue-router
烛衔溟19 分钟前
TypeScript 函数重载(Overloads)
javascript·ubuntu·typescript
CDwenhuohuo26 分钟前
小程序全局使用api
javascript·vue.js·小程序
whinc27 分钟前
Node.js技术周刊 2026年第16周
前端·javascript
DyLatte30 分钟前
我做了个AI项目后才发现:会做事的人,正在输给会讲故事的人
前端·后端·程序员
深海鱼在掘金30 分钟前
从Claude Code泄露源码看工程架构:第三章 — CLI 启动链路的分流策略与按需加载机制
前端·人工智能·设计模式
踩着两条虫30 分钟前
VTJ:低代码平台原理
前端·低代码·ai编程
颜酱32 分钟前
提示词强化1:三个让大模型更「听话」的习惯
前端·javascript·人工智能
破茧成蝶81032 分钟前
修复播报缺失文字的bug,改为“播放单个 -> 等待结束 -> 延迟 10ms秒 -> 播放下一个”的递归/循环模式
前端