uni-app踩坑记录-Canvas层级过高遮挡问题

现象

项目需求是在微信小程序里面做一个数据看板tabbar页,所以这里会用到图表,我用到是 ucharts库,同时页面会有popup弹框展示查询条件,项目里还用到了自定义底部tabbar,根据角色权限是否展示数据看板栏。这就导致了,弹框展开时和图表滚动到底部时,会将tabbar和弹框覆盖,如图:

分析

canvas 在微信小程序、百度小程序、QQ小程序中为原生组件,层级高于前端组件。参考:uniapp.dcloud.net.cn/component/c...

解决方案

因为我这不想将popup和自定义tabbar替换,所以排除用cover-view的方案。我这使用的是在图表绘制完成时,将canvas替换为图片。

js 复制代码
<div class="chart-box">
  <div class="chart-title">
    <div class="chart-name">反馈处理情况</div>
    <u-icon
      name="/static/images/data-statistics/icon-expand.png"
      @click="toExpand('bar')"
    ></u-icon>
  </div>
  <canvas
    canvas-id="bar"
    id="bar"
    class="charts-bar"
    @touchend="tap"
    v-show="barChartShow"
  />
  <image
    :src="barChartUrl"
    alt=""
    v-show="!barChartShow"
    :style="{
      width: cWidthBar + 'px',
      height: cHeightBar + 'px',
    }"
  ></image>
</div>
js 复制代码
// 画图表
this.drawBar("bar", currentBarData);
setTimeout(() => {
  uni.canvasToTempFilePath({
    canvasId: "bar",
    success: (res) => {
      this.barChartUrl = res.tempFilePath;
      this.barChartShow = false;
    },
  });
}, 1500);

就在我以为大功告成时,突然又出现一个新的坑,页面里有三种图表,通过tab切换显示,这里切换的时候需要重新调用图表数据接口,会重新渲染canvas,这就导致在切换的时候有一段时间底部tabbar栏还是会被遮盖。

然后就又换了另外一种方案,直接将canvas定位到页面外,过度期间使用loading来展示,渲染完图表后用图片替换loading。

代码:

js 复制代码
<div
    class="chart-content"
    v-show="chartParams.data_type === 1"
    @click="toDetail"
    >
    <div class="chrt-name">
      反馈问题分布图
      <!-- <span class="detail-link" @click.native="toDetail">查看详情</span> -->
    </div>
    <canvas
      canvas-id="ring"
      id="ring"
      class="charts-ring"
      @touchend.stop="tap"
    />
    <div
      :style="{
        width: cWidthBar + 'px',
        height: cHeightBar + 'px',
      }"
      class="chart-loading-box"
      v-show="ringChartShow"
    >
      <u-loading-icon size="36" class="chart-loading-icon"></u-loading-icon>
    </div>
    <image
      :src="ringChartUrl"
      alt=""
      v-show="!ringChartShow"
      :style="{
        width: cWidthRing + 'px',
        height: cHeightRing + 'px',
      }"
    ></image>
</div>
js 复制代码
.charts-bar {
    width: 650rpx;
    height: 530rpx;
    // margin: 0 auto;
    position: absolute;
    left: -999px;
    top: -999px;
}

.chart-loading-box {
  position: relative;
  margin: 0 auto;
  ::v-deep .u-loading-icon {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
  }
}

但是这样就会导致图表是没法交互的,这里就看具体需求的取舍了。

相关推荐
TA远方11 小时前
【HTML】JavaScript Canvas 图像截取与保存完整指南
前端·javascript·html·canvas·截图·截取
HYCS6 天前
用pixi.js实现fabric.js(六):从线性代数的角度理解编辑器交互
前端·javascript·canvas
戈德斯文10 天前
我做了一面互联网摸鱼墙:从无限 Canvas 到本地生产环境
react.js·canvas·next.js
七夜zippoe10 天前
OpenClaw Canvas A2UI:AI驱动的交互式界面开发实战
人工智能·canvas·交互式·a2ui·openclaw
QING61813 天前
如何使用Compose 绘制提升性能 —— 新手指南
kotlin·android jetpack·canvas
七夜zippoe13 天前
OpenClaw Canvas 截图:页面捕获与保存
canvas·捕获·页面·openclaw
七夜zippoe15 天前
OpenClaw Canvas 执行:JavaScript 注入实战
开发语言·javascript·udp·canvas·openclaw
HYCS15 天前
用pixi.js实现fabric.js(五):事件系统
前端·javascript·canvas
七夜zippoe17 天前
OpenClaw Canvas 导航:URL 加载与控制
canvas·url·导航·openclaw·加载与控制
名字都不重要何况昵称17 天前
canvas 分层渲染思路和脏矩形处理
前端·canvas