Echarts 图 报错 createLinearGradient

折线图和柱状图切换报错

 Uncaught TypeError: Failed to execute 'createLinearGradient' on 'CanvasRenderingContext2D': The provided double value is non-finite.

在这里插入图片描述

           yAxis: {
                 type: 'log',  //因为 type 为 log
                 minInterval: 1,
                 axisTick: {
                     show: false,
                 },                
             },
  • 把yAxis下的type属性设为log就可以调整数据差距过大的问题,我们可以看到y轴的数值呈现对数递增
  • log轴要求坐标数据大于0,这是由对数函数性质决定的,所以对于数据中含有0图形会出现异常

解决方法

  • 把数据为0的数据处理为undefined

在这里插入图片描述

  • 代码
    getListCheats(){
      // 初始化数据请求
      if (!this.isEditState) {
        this.lineChartData.timer = this.chartData.name || []
        if(this.lineChartData.timer.length>0){
          this.nothing = false
        }else{
          this.nothing = true
        }
          this.lineChartData.allData.zero = this.setData(this.chartData.value||[]) //主要是这行
        } else {
            this.getMockFn()
        }
    },
    // 这个方法
    setData(data=[]){
      let array = []
      data.forEach(v=>{
        array.push(v&&v!=0?v:undefined)
      })
      return array
    },
  • 处理tooltip的数据显示 (以上图例已经ok,下面的根据需求)
       formatter:function(params){
            console.log(params)
            let html = params[0].name
            params.forEach((item,index)=>{
                html+=(`<br/>${item.name}: ${item.value==undefined ? 0 : item.value}`)
            })
            return html;
        },
  • 以上就ok了!
  • 上图

在这里插入图片描述

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: createLinearGradient是一个CSS函数,用于创建一个线性渐变的颜色值。它可以接受多个参数,包括渐变的起点和终点的坐标,以及每个颜色的位置和值。通过这些参数,可以创建出不同方向、不同颜色、不同长度的线性渐变效果。 ### 回答2: createLinearGradient(创建线性渐变)是一种在网页中创建线性渐变背景的CSS属性。它通常用于设置元素的背景或边框的渐变效果。通过指定起始点和终点的坐标,可以创建水平、垂直或对角线方向的渐变效果。 在使用createLinearGradient时,需要指定两个或多个颜色值,并且可以设置每个颜色值所占据的百分比位置。例如,可以使用以下代码创建一个水平渐变背景: ``` background: linear-gradient(to right, red 0%, blue 100%); ``` 这将创建一个从左到右的渐变,起始颜色为红色,结束颜色为蓝色。 参数to right表示渐变的方向。除了to right之外,还可以使用to left、to top、to bottom或使用角度值(如45deg)来指定渐变方向。 通过指定更多的颜色和位置,可以创建更复杂的渐变效果,例如: ``` background: linear-gradient(to right, red 0%, orange 25%, yellow 50%, green 75%, blue 100%); ``` 这将创建一个由红、橙、黄、绿和蓝组成的五色渐变。 使用createLinearGradient可以实现更多丰富多样的渐变效果,如渐变背景、渐变边框等。需要根据具体需求来调整渐变的参数和属性,以达到想要的效果。 ### 回答3: createLinearGradient是一个CSS函数,用于创建线性渐变。它可以在CSS中的背景属性中使用,用来创建从一个颜色到另一个颜色的平滑过渡背景。 这个函数需要传入两个参数:起点位置和终点位置。位置可以使用绝对单位(如像素)或相对单位(如百分比)来定义。起点和终点的位置确定了渐变色的方向和长度。 可以使用角度或关键字来定义起点和终点的位置。例如,使用角度0deg表示从左到右渐变,90deg表示从上到下渐变,180deg表示从右到左渐变,270deg表示从下到上渐变。另外,还可以使用关键字如"top"、"bottom"、"left"、"right"来表示相应的方向。 除了起点和终点的位置,还需要指定两个或多个颜色值,这些颜色值将在渐变中过渡。可以使用颜色名、RGB、RGBA、十六进制等方式来定义颜色。 以下是一个示例: ```css /* 从左到右渐变 */ div { background: linear-gradient(to right, #ff0000, #0000ff); } ``` 这个示例创建了一个从红色到蓝色的线性渐变背景,方向为从左到右。 除了起点位置和终点位置,createLinearGradient还可以使用其他参数,如角度、渐变颜色的位置等,以实现更复杂的渐变效果。 createLinearGradient是一个强大的CSS函数,可以用于创建各种各样的渐变背景,为网页设计提供了更多的可能性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值