zoukankan      html  css  js  c++  java
  • 微信小程序中使用echarts

    一、效果图

    二、代码

    import * as echarts from '../../component/ec-canvas/echarts';
    const app = getApp();
    var xData = ["1:00", "2:00", "3:00", "4:00", "5:00", "6:00", "7:00", "8:00", "9:00", "10:00", "11:00", "12:00", "13:00", "14:00", "15:00"], yData = [], chart, charts, pc=0, mobile=0;
    function initChart(canvas, width, height) {
      chart = echarts.init(canvas, null, {
         width,
        height: height
      });
      canvas.setChart(chart);
      var option = {
        color: ["#37A2DA"],
        xAxis: {
          type: 'category',
          boundaryGap: false,
          data: xData,
        },
        yAxis: {
          x: 'center',
          type: 'value'
        },
        series: [{
          type: 'line',
          smooth: true,
          data: yData
        }]
      };
      chart.setOption(option);
      return chart;
    }
    function initCharts(canvas, width, height) {
      charts = echarts.init(canvas, null, {
         width,
        height: height
      });
      canvas.setChart(charts);
    
      var options = {
        color: ["#3498DB", "#E062AE"],
        tooltip: {
          trigger: 'item',
          formatter: "{a} {b}: {c} ({d}%)"
        },
        legend: {
          orient: 'vertical',
          x: 'left',
          paddingTop: '50px',
          data: ['移动端', 'PC端']
        },
        grid: {
          left: 20,
          right: 20,
          bottom: 15,
          top: 40,
          containLabel: true
        },
        
        series: [
          {
            name: '访问来源',
            type: 'pie',
            label: {
              normal: {
                show: true,
                position: 'outside',
                formatter: '{b}:{c}'
              },
              emphasis: {
                show: true,
                textStyle: {
                  fontSize: '20',
                  fontWeight: 'bold'
                }
              }
            },
            data: [
              { value: mobile, name: "移动端" },
              { value: pc, name:"PC端"}
            ]
          }
        ]
      };
    
      charts.setOption(options);
      return charts;
    }
    Page({
      data: {
        tabs: ["今日", "昨日", "近7日", "近30日"],
        activeIndex: 0,
        sliderOffset: 0,
        sliderLeft: 0,
        ec: {
          onInit: initChart
        },
        ecs: {
          onInit: initCharts
        }
      },
      onLoad: function (options) {
        var that = this;
        app.initNavbar(that);
      },
      onShow: function () {
        var that = this;
        setTimeout(function () {
          that.getDataInfo(0)
        }, 500)
      },
      tabClick: function (e) {
        this.setData({
          sliderOffset: e.currentTarget.offsetLeft,
          activeIndex: e.currentTarget.id
        });
        this.getDataInfo(e.currentTarget.id);
      },
      getDataInfo(index) {
        wx.showLoading({
          title: '正在加载...',
          mask: true
        });
        var that = this;
        wx.request({
          url: app.api.getData,
          data: {
            userid: wx.getStorageSync("userInfo").userid,
            action: index
          },
          success(res) {
            var yData = res.data.yData;
            var xData = res.data.xData;
            var option = chart.getOption();
            option.series[0].data = yData;
            option.xAxis = {
              type: 'category',
              boundaryGap: false,
              data: xData,
            };
            chart.setOption(option, true);
            var options = charts.getOption();
            options.series[0].data[0].value = res.data.mobile.num;
            options.series[0].data[1].value = res.data.pc.num;
            charts.setOption(options, true);
            that.setData({
              ip: res.data.ip,
              messall: res.data.messall,
              view: res.data.view
            })    
          },
          error() {
            app.errorModal("网络出错");
          },
          complete() {
            wx.hideLoading();
          }
        })
      }
    })
    
    <ec-canvas id="mychart-dom-line" canvas-id="mychart-line" ec="{{ ec }}"></ec-canvas>

    三、下载

    下载ec-cavas地址:https://github.com/ecomfe/echarts-for-weixin

    四、Demo

  • 相关阅读:
    消息传递协议
    TSL 访问器
    graph engine
    uwp 动画Storyboard
    iOS播放视频时候,忽略设备静音按钮
    Could not find Developer Disk Image
    GIT常用命令
    iOS 音频播放时听筒及扬声器切换
    iOS 9:ATS
    iOS设计模式
  • 原文地址:https://www.cnblogs.com/yang-2018/p/11076629.html
Copyright © 2011-2022 走看看