小程序 引入 es-canvas wx:for 单页面渲染多个for不同数据

<block wx:for="{{list}}" wx:key="sbh">
  <view style="height: 400px;width: 100%;">
    <ec-canvas id="charts-{{item.sbh}}" canvas-id="charts-{{item.sbh}}" ec="{{ ec }}"></ec-canvas>
  </view>
</block>

  

// pages/device/index.js
import * as echarts from '../components/ec-canvas/echarts';

var clearCharts = true;
//图表容器
let data=[
  {
    "type": "identifier",
    "list": [
      {
        "date": "2020/8/1",
        "num": 10
      },
      {
        "date": "2020/8/2",
        "num": 20
      },
      {
        "date": "2020/8/3",
        "num": 30
      }
    ]
  },
  {
    "type": "Overpressure",
    "list": [
      {
        "date": "2020/8/2",
        "num": 10
      },
      {
        "date": "2020/8/2",
        "num": 20
      },
      {
        "date": "2020/8/3",
        "num": 30
      }
    ]
  }
]
/**
 * 初始化图表
 * @param {*} canvas 
 * @param {*} width 
 * @param {*} height 
 * @param {*} dpr 
 */



Page({
  data: {
    list: [],
    data:data,
  }, 
  onLoad: function () {
    this.loadData();
  },
  loadData: function(){
    var that = this;
    var list = [];
    for(var i=0;i<6;i++){
      var num = uuid();
      list.push({'sbh':num});
    }
    that.setData({
      list: list
    })
    var arr=[]
    let xData=[]
    for(var i=0;i<list.length;i++){
      arr.push(this.selectComponent('#charts-'+list[i].sbh+''))
    }
    let datas=this.data.data;
    datas.forEach((aa,index)=>{
        xData.push(aa.list.map(item=>[item.date,item.num]))
      })
      console.log(xData)
    
    arr.forEach((item,index)=>{
        console.log(item,index)
        item.init((canvas, width, height, dpr) => {
          // 获取组件的 canvas、width、height 后的回调函数
          // 在这里初始化图表
          const chart = echarts.init(canvas, null, {
            width: width,
            height: height,
            devicePixelRatio: dpr // new
          });
          chart.setOption(getOption('111',xData[index]))
          // setOption(chart);
          // 将图表实例绑定到 this 上,可以在其他成员函数(如 dispose)中访问
          this.chart = chart;
          // 注意这里一定要返回 chart 实例,否则会影响事件处理等
          return chart;
        });
    })
  },


})

//图表配置项

function getOption(title,xData) {
  var option = {
    title: {
      text: '属性:'+title,
      left: 'center'
    },
    grid: {
      containLabel: true
    },
    tooltip: {
      show: true,
      trigger: 'axis'
    },
    xAxis: {
      type: 'category',
      boundaryGap: false,
      axisLabel:{
        interval:0,
        rotate:40
      }
  },
  yAxis: {
      type: 'value',
      boundaryGap: [0, '30%']
  },
  series: [
      {
          type: 'line',
          data:xData
      }
  ]
  };
  return option
}
function uuid() {
  var s = [];
  var hexDigits = "0123456789abcdef";
  for (var i = 0; i < 36; i++) {
    s[i] = hexDigits.substr(Math.floor(Math.random() * 0x10), 1);
  }
  s[14] = "4"; // bits 12-15 of the time_hi_and_version field to 0010
  s[19] = hexDigits.substr((s[19] & 0x3) | 0x8, 1); // bits 6-7 of the clock_seq_hi_and_reserved to 01
  s[8] = s[13] = s[18] = s[23] = "-";
 
  var uuid = s.join("");
  return uuid
}

  

.canvas{
  width: 100%;
  height: 100%;
}
.mychart{
  width: 100%;
  height: 800rpx;
  box-sizing: border-box;

}

  

posted @ 2020-09-19 17:16  顺其自然²º¹?  阅读(435)  评论(1编辑  收藏  举报