基于mpvue小程序使用echarts畫折線圖的方法示例
第一次使用mpvue框架來寫小程序,項目開發(fā)直接搬用mpvue-shop(一個仿網易嚴選的小程序開發(fā)項目),項目結構清楚,實現了大部分功能,對于初次使用mpvue的小伙伴們來說,是一個很好的選擇。
關于組件的選擇:
1.echarts-for-weixin,官方echarts的小程序版本。使用參考:echarts-for-weixin介紹,如果你是原生開發(fā)小程序版本,這個組件非常適合你,開發(fā)過程中可使用echarts官方提供的所有配置和Api,但并不適合mpvue項目。
2、wx-charts,一個個人開發(fā)的微信小程序圖表插件,體積只有30K,可用于mpvue項目和原生小程序項目,支持大部分圖表繪制,缺點是可配置化不強,對于UI沒有太大要求的可使用此組件,比較適合于個人項目開發(fā)。
3、mpvue-echarts與echarts結合。特別適合mpvue項目,mpvue-echarts是一個基于mpvue開發(fā)的echarts組件,echarts的加入可完全使用官方所有的圖表繪制功能,讓echarts在小程序當中得到全部應用。
mpvue-echarts配合echarts的使用
下載相關包
npm install mpvue-echarts --save
echarts的下載可到官網上下載,由于小程序中對文件大小有限制,建議通過勾選所需要的功能按需下載。
vue文件中使用
template:
<mpvue-echarts :echarts="echarts" :onInit="initChart" canvasId="demo-canvas" />
js:
import mpvueEcharts from 'mpvue-echarts';
let echarts = require("../../../static/lib/echarts.min.js"); //按需下載的壓縮文件放在項目文件夾中
import charts from './charts'; //本地mixin文件,圖表的所有配置
let chart = null;
export default {
data() {
return {
echarts,
};
},
async mounted() {
let data = await post("/product/marketInfo",{
});
this.initCombineLineData(data.trendData);
chart.setOption(this.trendChart);
},
mixins: [charts],
methods: {
initChart(canvas, width, height) {
chart = echarts.init(canvas, null, {
width: width,
height: height
});
canvas.setChart(chart);
chart.setOption(this.trendChart);
return chart;
}
},
components: {
mpvueEcharts
}
}
charts.js文件
export default {
data() {
return {
//trend圖
trendChart: {
grid: {
left: 'left',
top: 50,
containLabel: true,
tooltip: {
triggerOn: 'none',
showConent: true,
position: function (pt) {
return [pt[0], pt[1]-50];
}
}
},
tooltip: {
trigger: "none",
showContent: false,
},
textStyle: {
color: "#999",
fontSize: 24
},
label: {
fontSize: 22
},
xAxis: {
name: "年份",
type: "category",
nameGap:10, //坐標軸名稱與軸線之間的距離。
boundaryGap: true, //坐標軸兩邊留白策略
nameTextStyle:{ //坐標軸名稱樣式
color:"#999",
fontSize: 12,
align: 'left',
verticalAlign: 'bottom'
},
axisLine: { //坐標軸軸線相關設置
show: true, //是否顯示坐標軸軸線。
symbol: ['none','arrow'], //軸線兩邊的箭頭默認不顯示箭頭,即 'none'。兩端都顯示箭頭可以設置為 'arrow',只在末端顯示箭頭可以設置為 ['none', 'arrow']。
symbolSize: [10,8],//軸線兩邊的箭頭的大小
symbolOffset: [0,5],//軸線兩邊的箭頭的偏移
lineStyle: {
color: "#ece9e2",//線條顏色
},
},
axisTick: { //坐標軸刻度相關設置
show: false
},
axisLabel: { //坐標軸刻度標簽的相關設置
interval: 10000,
showMinLabel: true,
showMaxLabel: true,
fontSize: 12,
padding: [6, 0, 0, 0]
},
axisPointer: { //坐標軸指示器配置項
value: '',
snap: true,
type: 'line', //指示器類型
show: false, //豎線是否顯示,作用于每一個點
lineStyle: {
color: '#ece9e2',
width: 1
},
label: { //坐標軸指示器的文本標簽
show: false,
},
handle: { //拖拽手柄,適用于觸屏的環(huán)境
show: true,
color: 'none'
}
},
data: []
},
yAxis: {
type: "value",
name: "價格(元)",
nameGap: 0,
nameTextStyle:{
color:"#999",
fontSize: 12,
align: 'right',
verticalAlign: 'top',
padding: [0,0,10,60]
},
axisLine: {
show: true,
length: 100,
symbol: ['none','arrow'],
symbolSize: [10,8],
symbolOffset: [0,5],
lineStyle: {
color: "#ece9e2",
},
},
axisLabel: {
fontSize: 12,
formatter: value => {
return value;
}
},
axisTick: {
show: false
},
splitLine:{
lineStyle: {
//網絡線設置(只作用于非類目鈾)
show: true,
color: "#ece9e2",
width: 0.5,
type: "solid"
},
},
splitNumber: 5,
min: 0,
max: 4000,
interval: 1000
},
series: [
{
type: "line",
smooth: false,
color: "#ca3c2e",
showSymbol: true,
lineStyle: {
width: 1.5,
color: "#c5936e",
},
itemStyle: {
normal:{
borderWidth: 0.5,
label:{
show: true, //顯示值
borderWidth: 2,
color: '#c5936e',
fontSize: 12,
}
}
},
data: []
},
]
},
};
},
methods: {
initCombineLineData(data) {
this.trendChart.xAxis.axisPointer.value = data[data.length-1].date; //讓指示器定位在最后一個折線點上
for(let i=0;i<=data.length;i++){
let yData = {
symbol: 'none' //折線上不顯示轉折點
};
if(i== data.length-1){
yData.symbol = "emptyCircle", //最后一個顯示轉折點
yData.symbolSize = 6
}
yData.value = data[i].price;
this.trendChart.xAxis.data.push(data[i].date);
this.trendChart.series[0].data.push(yData);
}
},
}
};
最終效果

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
JavaScript高級程序設計 閱讀筆記(七) ECMAScript中的語句
ECMAScript中的語句,學習js的朋友可以參考下2012-02-02
Javascript保存網頁為圖片借助于html2canvas庫實現
借助于html2canvas庫,把網頁保存為Canvas畫布,再把生成的canvas保存成圖片,下面的示例,大家可以看看2014-09-09
解決layer.confirm快速點擊會重復觸發(fā)事件的問題
今天小編就為大家分享一篇解決layer.confirm快速點擊會重復觸發(fā)事件的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09
解決 viewer.js 動態(tài)更新圖片導致無法預覽的問題
Viewer.js 是一款強大的圖片查看器,這篇文章主要介紹了解決 viewer.js 動態(tài)更新圖片導致無法預覽的問題 ,需要的朋友可以參考下2019-05-05

