微信小程序echart图表canvas层级太高覆盖解决办法

最近在使用echart图表时,发现滚动页面时,echart图表层级覆盖原生组件,设置z-index无效。

微信小程序echarts组件:echarts-for-wx

先看症状:
在这里插入图片描述

解决办法:
发现原来的echarts-for-wx组件里有个方法。
初始化echart后:
效果图:
在这里插入图片描述小程序演示:
在这里插入图片描述

canvasToTempFilePath(opt) {
      if (this.data.isUseNewCanvas) {
        // 新版
        const query = wx.createSelectorQuery().in(this)
        query.select('.ec-canvas').fields({ node: true, size: true }).exec(res => {
            const canvasNode = res[0].node
            opt.canvas = canvasNode
            wx.canvasToTempFilePath(opt)
          })
      } else {
        // 旧的
        if (!opt.canvasId) {
          opt.canvasId = this.data.canvasId;
        }
        ctx.draw(true, () => {
          wx.canvasToTempFilePath(opt, this);
        });
      }
    },

在调用页面

data:{
	echarts_show: true,
    canvas_image: '',
}
initChart()
{
var ec_Component = this.selectComponent('#mychart-dom-line');
setTimeout(()=>{
  ec_Component.canvasToTempFilePath({
    success: res => {
      // console.log('drawSuccess', res.tempFilePath);
      this.setData({
        canvas_image: res.tempFilePath,
      })
    },
    fail: res => console.log('失败', res)
  })
},1000)
}
//滚动到临界点时隐藏canvas,显示图片
onPageScroll()
{
	let query = wx.createSelectorQuery()
    query.select('#tide-echart').boundingClientRect((rect) => {
      let top = rect.top;
      //缓存图片不要在这里设置,在inchart时就设置,防止切换图片闪烁
        this.setData({
          echarts_show: false,
        })
      } else {
        this.setData({
          echarts_show: true,
          // canvas_image:''
        })
      }
    }).exec()
}

wxml页面:

<view class="tide-box" id="tide-echart">
  <view class="container" hidden="{{!echarts_show}}">
    <ec-canvas id="mychart-dom-line" type="2d" canvas-id="mychart-line" ec="{{ ec }}"></ec-canvas>
  </view>
  <image class="canvas-image" src="{{canvas_image}}" hidden="{{echarts_show}}"></image>
</view>

相关推荐

  1. 程序canvas画布不清晰解决方法

    2024-04-25 12:58:03       43 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-25 12:58:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-25 12:58:03       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-25 12:58:03       82 阅读
  4. Python语言-面向对象

    2024-04-25 12:58:03       91 阅读

热门阅读

  1. 上位机工作感想-从C#到Qt的转变-2

    2024-04-25 12:58:03       34 阅读
  2. 算法训练营day22

    2024-04-25 12:58:03       30 阅读
  3. 【二叉树算法题记录】226. 翻转二叉树

    2024-04-25 12:58:03       34 阅读
  4. HOT100与剑指Offer

    2024-04-25 12:58:03       32 阅读
  5. 监督算法建模前数据质量检查

    2024-04-25 12:58:03       28 阅读
  6. mapreduce序列化(Hadoop)

    2024-04-25 12:58:03       25 阅读