基于mpvue小程序使用echarts畫(huà)折線圖的方法示例
第一次使用mpvue框架來(lái)寫(xiě)小程序,項(xiàng)目開(kāi)發(fā)直接搬用mpvue-shop(一個(gè)仿網(wǎng)易嚴(yán)選的小程序開(kāi)發(fā)項(xiàng)目),項(xiàng)目結(jié)構(gòu)清楚,實(shí)現(xiàn)了大部分功能,對(duì)于初次使用mpvue的小伙伴們來(lái)說(shuō),是一個(gè)很好的選擇。
關(guān)于組件的選擇:
1.echarts-for-weixin,官方echarts的小程序版本。使用參考:echarts-for-weixin介紹,如果你是原生開(kāi)發(fā)小程序版本,這個(gè)組件非常適合你,開(kāi)發(fā)過(guò)程中可使用echarts官方提供的所有配置和Api,但并不適合mpvue項(xiàng)目。
2、wx-charts,一個(gè)個(gè)人開(kāi)發(fā)的微信小程序圖表插件,體積只有30K,可用于mpvue項(xiàng)目和原生小程序項(xiàng)目,支持大部分圖表繪制,缺點(diǎn)是可配置化不強(qiáng),對(duì)于UI沒(méi)有太大要求的可使用此組件,比較適合于個(gè)人項(xiàng)目開(kāi)發(fā)。
3、mpvue-echarts與echarts結(jié)合。特別適合mpvue項(xiàng)目,mpvue-echarts是一個(gè)基于mpvue開(kāi)發(fā)的echarts組件,echarts的加入可完全使用官方所有的圖表繪制功能,讓echarts在小程序當(dāng)中得到全部應(yīng)用。
mpvue-echarts配合echarts的使用
下載相關(guān)包
npm install mpvue-echarts --save
echarts的下載可到官網(wǎng)上下載,由于小程序中對(duì)文件大小有限制,建議通過(guò)勾選所需要的功能按需下載。
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"); //按需下載的壓縮文件放在項(xiàng)目文件夾中
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, //坐標(biāo)軸名稱(chēng)與軸線之間的距離。
boundaryGap: true, //坐標(biāo)軸兩邊留白策略
nameTextStyle:{ //坐標(biāo)軸名稱(chēng)樣式
color:"#999",
fontSize: 12,
align: 'left',
verticalAlign: 'bottom'
},
axisLine: { //坐標(biāo)軸軸線相關(guān)設(shè)置
show: true, //是否顯示坐標(biāo)軸軸線。
symbol: ['none','arrow'], //軸線兩邊的箭頭默認(rèn)不顯示箭頭,即 'none'。兩端都顯示箭頭可以設(shè)置為 'arrow',只在末端顯示箭頭可以設(shè)置為 ['none', 'arrow']。
symbolSize: [10,8],//軸線兩邊的箭頭的大小
symbolOffset: [0,5],//軸線兩邊的箭頭的偏移
lineStyle: {
color: "#ece9e2",//線條顏色
},
},
axisTick: { //坐標(biāo)軸刻度相關(guān)設(shè)置
show: false
},
axisLabel: { //坐標(biāo)軸刻度標(biāo)簽的相關(guān)設(shè)置
interval: 10000,
showMinLabel: true,
showMaxLabel: true,
fontSize: 12,
padding: [6, 0, 0, 0]
},
axisPointer: { //坐標(biāo)軸指示器配置項(xiàng)
value: '',
snap: true,
type: 'line', //指示器類(lèi)型
show: false, //豎線是否顯示,作用于每一個(gè)點(diǎn)
lineStyle: {
color: '#ece9e2',
width: 1
},
label: { //坐標(biāo)軸指示器的文本標(biāo)簽
show: false,
},
handle: { //拖拽手柄,適用于觸屏的環(huán)境
show: true,
color: 'none'
}
},
data: []
},
yAxis: {
type: "value",
name: "價(jià)格(元)",
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: {
//網(wǎng)絡(luò)線設(shè)置(只作用于非類(lèi)目鈾)
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; //讓指示器定位在最后一個(gè)折線點(diǎn)上
for(let i=0;i<=data.length;i++){
let yData = {
symbol: 'none' //折線上不顯示轉(zhuǎn)折點(diǎn)
};
if(i== data.length-1){
yData.symbol = "emptyCircle", //最后一個(gè)顯示轉(zhuǎn)折點(diǎn)
yData.symbolSize = 6
}
yData.value = data[i].price;
this.trendChart.xAxis.data.push(data[i].date);
this.trendChart.series[0].data.push(yData);
}
},
}
};
最終效果

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- vue+echarts實(shí)帶漸變效果的折線圖
- vue+echart實(shí)現(xiàn)圓滑折線圖
- Vue+Echarts實(shí)現(xiàn)柱狀折線圖
- Vue+Echarts實(shí)現(xiàn)簡(jiǎn)單折線圖
- vue+echarts實(shí)現(xiàn)多條折線圖
- vue使用echarts實(shí)現(xiàn)折線圖
- vue使用ECharts實(shí)現(xiàn)折線圖和餅圖
- vue+echarts實(shí)現(xiàn)動(dòng)態(tài)折線圖的方法與注意
- 在vue中使用echarts(折線圖的demo,markline用法)
- vue+F2生成折線圖的方法
相關(guān)文章
CSS+JS實(shí)現(xiàn)點(diǎn)擊文字彈出定時(shí)自動(dòng)關(guān)閉DIV層菜單的方法
這篇文章主要介紹了CSS+JS實(shí)現(xiàn)點(diǎn)擊文字彈出定時(shí)自動(dòng)關(guān)閉DIV層菜單的方法,設(shè)計(jì)javascript操作菜單的彈出與關(guān)閉的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-05-05
JavaScript高級(jí)程序設(shè)計(jì) 閱讀筆記(七) ECMAScript中的語(yǔ)句
ECMAScript中的語(yǔ)句,學(xué)習(xí)js的朋友可以參考下2012-02-02
javaScript中push函數(shù)用法實(shí)例分析
這篇文章主要介紹了javaScript中push函數(shù)用法,較為詳細(xì)的分析了javascript中push函數(shù)的功能、定義及使用技巧,需要的朋友可以參考下2015-06-06
Javascript保存網(wǎng)頁(yè)為圖片借助于html2canvas庫(kù)實(shí)現(xiàn)
借助于html2canvas庫(kù),把網(wǎng)頁(yè)保存為Canvas畫(huà)布,再把生成的canvas保存成圖片,下面的示例,大家可以看看2014-09-09
解決layer.confirm快速點(diǎn)擊會(huì)重復(fù)觸發(fā)事件的問(wèn)題
今天小編就為大家分享一篇解決layer.confirm快速點(diǎn)擊會(huì)重復(fù)觸發(fā)事件的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
json字符串對(duì)象轉(zhuǎn)換代碼實(shí)例
這篇文章主要介紹了json字符串對(duì)象轉(zhuǎn)換代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09
bootstrap-treeview自定義雙擊事件實(shí)現(xiàn)方法
這篇文章主要介紹了bootstrap-treeview自定義事件雙擊事件實(shí)現(xiàn)方法,需要的朋友可以參考下2016-01-01
解決 viewer.js 動(dòng)態(tài)更新圖片導(dǎo)致無(wú)法預(yù)覽的問(wèn)題
Viewer.js 是一款強(qiáng)大的圖片查看器,這篇文章主要介紹了解決 viewer.js 動(dòng)態(tài)更新圖片導(dǎo)致無(wú)法預(yù)覽的問(wèn)題 ,需要的朋友可以參考下2019-05-05
js實(shí)現(xiàn)盒子滾動(dòng)動(dòng)畫(huà)效果
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)盒子滾動(dòng)動(dòng)畫(huà)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08

