zoukankan      html  css  js  c++  java
  • echarts和v-chart使用心得

    echarts的响应式

    每次窗口大小改变的时候都会触发onresize事件,这个时候我们将echarts对象的尺寸赋值给窗口的大小这个属性,从而实现图表对象与窗口对象的尺寸一致的情况
    window.onresize = echart.resize;
    echart.setOption(option);

    echarts异步请求

    使用ajax获取数据的时候,可以先设置完其他样式,显示一个空直角坐标。然后用ajax获取数据请求。

    x轴数据显示不全,被截取的操作

    当X轴上面要渲染的数据太多的时候就会出现只渲染出来一部分,但是图表中的数据显示(比如说柱状图中的每个柱子)又会自动的进行宽度的缩放,所以会导致X轴与图中的信息不相匹配的问题,解决的方法是在X轴设置axisLabel :{ interval:0 }这个属性问题就可以解决了,Y轴的使用方法相同

    当碰到有tab切换时,再显示图表出现的问题
    最近在使用echart时,出现了一个问题就是:手机上使用echarts,页面中有tab切换图表。除了第一个可以正常显示外,其他的图表的宽度必须设置成很大。比如说第一个tab的图表的宽度我设置为100%,第二个tab图表的宽我必须设置成300%才行。而且使用grid还不行。在手机端需要做适配,所以设置具体的宽度并不好,设置成百分比会出现问题。

    解决:

    原因:原因可能是在进行tab切换时,其宽度并没有加载出来。此时,我们需要将宽度重新加载一遍。

    document.getElementById('box').style.width = window.innerWidth+'px';
    获取屏幕宽度,echarts的宽度和屏幕的宽度一致

    let box= echarts.init(document.getElementById('box'));
    再进行初始化,这个时候设置宽度为百分之100就可以了。不用担心适配问题

    v-charts用法小结
    v-charts是基于echarts的二次封装,使用起来异常方便,地址:https://v-charts.js.org/#/。

    功能没有echarts那么丰富,但一般情况下是够用了。在这里不讲怎么引入,使用,直接看官方的api即可。由于其API写的比较简单。因此在使用过程中踩过不少的坑,现做一个小结,方便后来人。

    1.在v-charts中使用xAxis

    在v-charts中使用xAxis时,需要执行3步。第一个步骤是在html中使用:xAxis=“xAxis”;第二步是在data里面定义xAxis,声明为一个空对象;第三步也就是非常重要的一步就是在methods中,使用

    this.xAxis={}

    但是在这一步,我们相当于是用xAxis将原有的覆盖了,所以我们要在this.xAxis中重新定义横坐标data,否则图表会变形。只要重新定义了data,之后我们就可以使用xAxis的其他任何属性了。

    2、横坐标被截取

    横坐标太多不能显示完全,常用的解决办法有两种:

    一种是横坐标倾斜,一种就是自定义横坐标间距。

    this.xAxis = {
    type:'category',
    data:rows1,
    boundaryGap:true,
    axisLabel:{
    rotate:30,
    interval:0
    }
    };
    用法和echarts类似,interval表示间距,为0表示横坐标数据全部展示,rotate表示倾斜角度。

    如果不想使用倾斜,那就自定义间隔,设置interval的数值即可。

    但是我在实际工作中,还碰到一个问题就是:同样的代码,同样的浏览器,同样的电脑配置,当横坐标是日期时,横坐标最右边的数值被截取了。这让我很是无语。找了很多原因,最后解决的办法是加上:grid=grid,然后给grid设置right值才解决的。

    3、图表不出现或只出现一部分

    最近的一个项目中,使用v-chart在本地显示正常,但项目上线后显示不正常,只显示出一部分。其中原因我也不是很明白。最后只是将图表的宽度由原来的100%改为具体的px,这才显示完全。可能数据在传输的时候有网络问题,导致百分数不能解析吧。


    原文链接:https://blog.csdn.net/weixin_38384967/article/details/87692513

  • 相关阅读:
    BZOJ4569 : [Scoi2016]萌萌哒
    2016浙江省赛过山车记
    BZOJ4546(原) : 三元组
    BZOJ4539 : [Hnoi2016]树
    BZOJ4537 : [Hnoi2016]最小公倍数
    BZOJ4538 : [Hnoi2016]网络
    BZOJ4527 : K-D-Sequence
    BZOJ4504 : K个串
    BZOJ4471 : 随机数生成器Ⅱ
    BZOJ3659 : Which Dreamed It
  • 原文地址:https://www.cnblogs.com/colorful-paopao1/p/11435404.html
Copyright © 2011-2022 走看看