uniapp小程序ucharts层级过高
- 为什么canvas组件总是会在最上层?
由于canvas组件是原生组件,原生组件的层级是最高的,所以页面中的其他组件无论设置 z-index 为多少,都无法盖在原生组件上 - 在页面出现点击事件,存在弹框,ucharts的图层会会出现在弹框上层,ucharts的图层事件会超过弹框事件,导致样式出现问题。
可以在弹框显示的时候,将ucharts图形,转换称图片的形式显示。
使用v-show的方式,切换显示。从而不会出现层级的问题。 - 部分代码如下,不可以直接运行
<view class="charts-box">
<canvas v-show="!BugShow" canvas-id="drawxychartsmonth" id="drawxychartsmonth" class="charts" @touchend="tap"/>
<image v-show="BugShow" :src="canvasImg" style="width: 650rpx; height: 300rpx;" />
</view>
//这里的 750 对应 css .charts 的 width
this.cWidth = uni.upx2px(600);
//这里的 500 对应 css .charts 的 height
this.cHeight = uni.upx2px(300);
drawCharts(id,data){
const ctx = uni.createCanvasContext(id, this);
var that=this;
uChartsInstance[id] = new uCharts({
type: "area",
context: ctx,
width: this.cWidth,
canvas2d:true,
canvasId: id,
height: this.cHeight,
categories: data.categories,
series: data.series,
animation: true,
background: "#FFFFFF",
dataLabel:false,
color: ["#1890FF","#91CB74","#FAC858","#EE6666","#73C0DE","#3CA272","#FC8452","#9A60B4","#ea7ccc"],
padding: [15,0,0,0],
legend: {
show:false,
},
xAxis: {
disableGrid: true,
boundaryGap:'justify',
fontSize:"10",
formatter: function (value, index,opts) {
if(index=='0' || index==(opts.categories.length-1)){
return value;
}else{
return ""
}
},
axisLabel: {//x轴文字的配置
show: true,
interval: 0,//使x轴文字显示全
}
},
yAxis: {
type: "value",
gridType: "solid",
axisTick: {
inside: true
},
scale: true,
data:[
{
fontSize:"10",
formatter: function (value, index,opts) {
if(that.tipType=="2"){
return formatAmount(value, 4)
}else if(that.ischartsPro){
return formatAmount(value, 3) + '%'
}else{
return formatAmount(value, 4)
}
},
}
],
axisLabel: {
margin: 2,
show: true,
},
},
grid: { x: 45, y: 20, x2: 16, y2: 8, width: 'auto', height: 'auto', left: '20%' },
extra: {
tooltip:{
showBox:true,
showArrow:false,
borderRadius:5,
fontColor:"#4f9acc",
bgOpacity:"1",
bgColor:"#ffffff",
borderWidth:"1",
borderColor:"#7698ad",
labelBgColor: "#FFFFFF",
},
area: {
type: "curve",
opacity: 0.5,
addLine: true,
width: 2,
gradient: true,
activeType: "hollow"
},
}
});
},
tap(e){
var that=this;
uChartsInstance[e.target.id].touchLegend(e);
uChartsInstance[e.target.id].showToolTip(e,{
formatter: (item, category, index, opts) => {
if(that.tipType=="1" && that.ischartsPro){
return "自定义/"+item.name + ":" + formatAmount(item.data, 3)+ '%' +'/'+'日期'+ ":" +category;
}else{
return "自定义/"+item.name + ":" + formatAmount(item.data, 4) +'/'+'日期'+ ":" +category;
}
}
});
},
// 需要让 弹窗等 出现在canvas上的事件
handleCanvarToImg() {
var that=this;
uni.canvasToTempFilePath({
x: 0,
y: 0,
width: 650,
height: 300,
canvasId: 'drawxychartsmonth',
success: function(res) {
that.canvasImg=res.tempFilePath;
}
});
},```