一、示例
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%;}