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%);
  }
}

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

相关推荐
似水流年_zyh3 天前
canvas写一个选择音频区域的组件
前端·canvas
STCNXPARM3 天前
Android14显示系统 - 图形库canvas\HWUI\skia
canvas·skia·android图形库
holidaypenguin5 天前
【转】跨浏览器 Canvas 图像解码终极方案:让大图渲染也能丝滑不卡顿
前端·canvas
普兰店拉马努金9 天前
【Canvas与旗帜】标准比例挪威国旗
canvas·旗帜·挪威
德育处主任12 天前
在小程序做海报的话,Painter就很给力
前端·微信小程序·canvas
熊猫钓鱼>_>15 天前
解决Web游戏Canvas内容在服务器部署时的显示问题
服务器·前端·游戏·canvas·cors·静态部署·资源路径
Lsx_17 天前
案例+图解带你一文读懂Svg、Canvas、Css、Js动画🔥🔥(4k+字)
前端·javascript·canvas
狂龙骄子17 天前
uniapp圆形时钟
小程序·uniapp·canvas·clock·圆盘时钟
若梦plus18 天前
Canvas基础
前端·canvas
若梦plus18 天前
Canvas的未来之AI绘图、生成式视觉与XR
前端·canvas