微信小程序中使用echart、动态加载几条折线

一、示例

 echart小程序示例

gitub地址:GitHub - ecomfe/echarts-for-weixin: Apache ECharts 的微信小程序版本

在小程序中放入

效果

 

二、 小程序代码

json 组件的位置取决于一示例中的的echart的位置

{  
  "navigationStyle":"custom",
  "usingComponents": {
    "ec-canvas":"../../ec-canvas/ec-canvas"
  }
}

wxml

<coverheader headerOpt="{{headerOpt}}"></coverheader>
<wxs src="./../../filter/urlFilter.wxs" module="filter" /> 
<view class="tendency">
<view class="chartScreen">
  <view class="chart_item" wx:for="{{tendencyList}}" wx:key="index">
    <view class="check {{!filter.includesArr(chooseId,item.value)?'checked'+index:''}}" bindtap="clickcheck" data-item="{{item}}"></view>
    <view>{{item.label}}</view>
  </view>
</view>
<view class="echart_line">
  <view class="echart_line1">
    <ec-canvas id="mychart" canvas-id="mychart" ec="{{ ec }}"></ec-canvas>
  </view>         
</view>
</view>

js

var request = require('../../utils/request.js');
let util=require('../../utils/util')
import {getTopicAnalysis } from "../../utils/api/test/test";
import * as echarts from '../../ec-canvas/echarts';
Page({

  /**
   * 页面的初始数据
   */
  data: {
    headerOpt:{
      showGoHome:false,
      title:"详情页",
      // styles:'background-image:url(https://assets-dajieimg.oss-cn-beijing.aliyuncs.com/meishu/login/bg_top.png);background-size:100% 100%'
    },
    navigationBarAndStatusBarHeight:wx.getStorageSync('statusBarHeight') + wx.getStorageSync('navigationBarHeight') + 'px',
    tendencyList:[{label:'1',value:1},{label:'2',value:2},{label:'3',value:3},{label:'4',value:4},{label:'5',value:5},{label:'6',value:6,}],
    chooseList:[],//选中的list
    chooseId:[],//选中的id
    ec: {
      lazyLoad: true // 延迟加载
    },
    Chart:null,
  },
  clickcheck(e){
    let that=this
    let items=e.currentTarget.dataset.item
    let id=e.currentTarget.dataset.item.value
    let chooseId=that.data.chooseId
    let chooseList=that.data.chooseList
    console.log(id);
    // 如果id不存在加入
    if(!chooseId.includes(id)){
      chooseId.push(id)
      chooseList.push(items)
    }else{
      //删除id
      var index = chooseId.findIndex(item => {return item === id})
      chooseId.splice(index,1)
      chooseList.splice(index,1)
    }
    console.log(chooseId);
    that.setData({
      chooseId,
      chooseList,
    })
    that.getseriesInfo()
  },
  getseriesInfo(){
    let colorArr= ['#556FFD', '#57BE6A', '#DF699B', '#98A1D0', '#EED46C','#D64052','#E3C24B']
    //传递的参数--
    getTopicAnalysis({chooseId:this.data.chooseId}).then((res)=>{
        if(res.data){
          let xAxisinfo = [];
          let legendInfo = [];
          let seriesInfo = [];
          res.data.forEach((ele,index) => {
              let params = {
                  data: [],
                  type: 'line',
                  showSymbol: false,
                  name: '',
                  lineStyle:{
                    color:colorArr[index]
                  },
              };
              legendInfo.push(ele.topicName)//topicId 话题id
              params.name = ele.topicName;
               ele.dailyData.forEach((eleData) => {
                      if(index == 0){
                          xAxisinfo.push(eleData.date)
                      }
                      params.data.push(eleData.cnt)
                  });
                  seriesInfo.push(params);
             })
              this.setData({
                xAxisinfo,
                legendInfo,
                seriesInfo
              })
              console.log(seriesInfo);
          if (!this.data.Chart){
            this.init_echarts(); //初始化图表
          }else{
            this.setOption(); //更新数据
          }
          console.log(seriesInfo);
        }
    })
  },
   //综合数据图标初始化
 init_echarts: function () {
  this.echartsComponnet.init((canvas, width, height,dpr) => {
    // 初始化图表
    const Chart = echarts.init(canvas, null, {
     // renderer: 'svg',
      width: width,
      height: height,
      devicePixelRatio: dpr // new
    });
    Chart.setOption(this.setOption());
    // 注意这里一定要返回 chart 实例,否则会影响事件处理等
    return Chart;
  });
},
//综合数据直线设置数据
setOption(){
  return {
  //  color: ['#DC2FDC', '#1B89FF', '#87EEFB', '#EEAD6C', '#EED46C'],
   tooltip: {
        trigger: 'axis',
      confine: true,
      // showContent: false,
      backgroundColor: 'rgba(255,255,255,0.5)',
      borderWidth: 1,
      borderColor: '#e2e6f5',
      borderRadius: 4,
      padding: [10, 20, 10, 20],
      textStyle: {
          color: "#949AB7",
      },
      axisPointer: {
          type: "cross",
          label: {
            show:false,
          // backgroundColor: 'rgba(39, 100, 131, 0.71)',
          // backgroundColor: 'null',
          },
          lineStyle:{
          backgroundColor: 'rgba(39, 100, 131, 0.71)',
          }
      },
    formatter: function (params) {
        let str = params[0].name+'\n'
        let newParams = [];
        let tooltipString = [];
        newParams = [...params];
        newParams.sort((a,b) => {return Number(b.value) - Number(a.value)});
        newParams.forEach((ele,index) => {
                str +=ele.seriesName+ele.value+'\n'
        })
        return  str
    }
},
    grid: {
      left: 20,
      right: 20,
      bottom: 15,
      top: 40,
      containLabel: true
    },
    legend: {
     icon:'circle', 
     show:false,
     itemHeight: 12,
     itemWidth: 12,
     top:'bottom',
     textStyle: { 
     //图例文字的样式
         color: '#3F96D5',
         fontSize: 12
     },
     data: this.data.legendInfo,
   },
   xAxis: {
    axisLabel:{
      color: "#9095A7", //刻度线标签颜色
      lineStyle:{
      color:'#9095A7',//更改坐标轴颜色
     },
     },
     axisTick:{show:false},
     axisPointer: {
         lineStyle:{
             color:'rgba(39, 100, 131, 1)'
         }
     },
     //设置轴线的属性
     axisLine:{
         lineStyle: {
         color: '#DFE1EB',//刻度线的颜色
       }
     },
     type: 'category',
     boundaryGap: false,
     data: this.data.xAxisinfo,
 },
 yAxis: {
  splitLine: {
    lineStyle: {
      type: 'dashed',
      color:'#DFE1EB'
    }
   },
   boundaryGap: [0, '50%'],
   type: 'value',
  //  name: 'GMV',
   position: 'left',
   axisLabel: {
       color: "#9095A7", //刻度线标签颜色
       formatter(v) {
           v = v.toString()
           if (v >= 100000000000) {
               return (v.substring(0, 5) / 10) + '亿'
           } else if (v >= 10000000000) {
               return (v.substring(0, 4) / 10) + '亿'
           } else if (v >= 1000000000) {
               return (v.substring(0, 3) / 10) + '亿'
           } else if (v >= 100000000) {
               return (v.substring(0, 2) / 10) + '亿'
           } else if (v >= 10000000) {
               return v.substring(0, 4) + 'w'
           } else if (v >= 1000000) {
               return v.substring(0, 3) + 'w'
           } else if (v >= 100000) {
               return v.substring(0, 2) + 'w'
           } else if (v >= 10000) {
               return (v.substring(0, 2) / 10) + 'w'
           } else if (v >= 1000) {
               return v
           } else {
               return v
           }
       },
   },
   axisPointer: {
     lineStyle:{
         color:'rgba(39, 100, 131, 1)'
     }
 },
},
series: this.data.seriesInfo,
grid: {top: '5%',right:'8%',bottom:'10%',left:'14%'},
}
    
},

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    this.echartsComponnet = this.selectComponent('#mychart');
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})

wxss

page{
  background-color: #F5F5F5;
  color:#212848;
}
.tendency{background-color: #fff;padding: 30rpx;margin-top:20rpx ;}
.sec_title{font-size: 32rpx;font-weight: 500;margin-bottom: 36rpx;}
.chartScreen{display: flex;align-items: center;flex-wrap: wrap;}
.chart_item{display: flex;align-items: center;flex-shrink: 0;margin-right: 30rpx;font-size: 24rpx;margin-bottom: 18rpx;}
.check{width: 28rpx;height: 28rpx; border: 2rpx solid #dbdbdb;border-radius: 4rpx;margin-right: 8rpx;}
.checked0{background: url('') no-repeat;background-size: 100% 100%;}
.checked1{background: url('') no-repeat;background-size: 100% 100%;}
.checked2{background: url('') no-repeat;background-size: 100% 100%;}

.checked3{background: url('') no-repeat;background-size: 100% 100%;}

.checked4{background: url('') no-repeat;background-size: 100% 100%;}

.checked5{background: url('') no-repeat;background-size: 100% 100%;}

.echart_line{display: flex;align-items: center;}
.echart_line .echart_line1{height: 420rpx;width:100%;}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值