欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信小程序+ECharts實現(xiàn)動態(tài)刷新的過程記錄

 更新時間:2021年05月07日 15:09:39   作者:海賊王的迷妹  
這篇文章主要給大家介紹了關(guān)于微信小程序+ECharts實現(xiàn)動態(tài)刷新的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

最近遇到了一個需求,就是要在小程序中實時刷新圖表,最開始選擇的是wx-chart,然后發(fā)現(xiàn)不能滿足我的需求,最后選擇了ECharts,也踩了一些坑,通過在網(wǎng)上收集資料,終于弄出來了,記錄下我實現(xiàn)的過程。

方法實例

1.首先到ECharts官網(wǎng)下載它的例子,然后把ec-canvas文件拷貝下來放到你自己的項目中:

2.然后在你需要用的頁面引入,在xxx.json中加入,這里要注意路徑,我的頁面統(tǒng)一是放在pages文件夾中的:

"usingComponents": {
    "ec-canvas": "../../ec-canvas/ec-canvas"
 }

3.Ok,開始干正事了,我這里就舉一個頁面兩個圖表的例子,先把簡單的布局和樣式弄好

xxx.wxml:

需要提供兩個canvas盒子:

<view class="content">
    <ec-canvas id="mychart-one" canvas-id="mychart-multi-one" ec="{{ ecOne}}"></ec-canvas>
    <ec-canvas id="mychart-two" canvas-id="mychart-multi-two" ec="{{ ecTwo }}"></ec-canvas>
</view> 

xxx.wxss:

.content {
    width: 100%;
    background-color: #F2F2F2;
    overflow-y: auto;
}
#mychart-one {
    position: absolute; 
    top: 0;
    height: 50%;
    left: 0;
    right: 0;
}
#mychart-two {
    position: absolute; 
    top: 50%;
    height: 50%;
    left: 0;
    right: 0;
}

這里值得注意的是,如果你想放三個圖表,四個圖表或者多個,一定要設(shè)canvas盒子的高度,要不然你會發(fā)現(xiàn)后面兩個表咋不見了??!官方的多個圖表沒有設(shè)高度,所以我照官方的放了幾個圖,發(fā)現(xiàn)都沒有,心累,找了半天,才發(fā)現(xiàn)是樣式問題,索性每個盒子都設(shè)了50%的高度。

4.好了,準(zhǔn)備條件都做足,接下來就是重頭戲了,(其實我覺得我寫的好繁瑣,全是重復(fù)的代碼,不過暫時也沒時間整合了,有興趣的朋友可以自己寫方法整合一下啦)

xx.js

首先肯定就是要在頁面最開始引入那個官方的組件了

import * as echarts from '../../ec-canvas/echarts';

先將表格要展示的樣式配置之類的設(shè)好

function setOption(chart, xdata, ydata) {
    const option = {
        title: {
            text: '測試',
            padding: [10, 0, 0, 20],
            textStyle: {
                fontSize: 14,
                color: '#696969'
            },
            top: '10rpx'
        },
        backgroundColor: "#fff",
        color: ["#006EFF", "#67E0E3", "#9FE6B8"],
        animation: false,
        grid: {
            show: false
        },
        xAxis: {
            type: 'category',
            data: xdata,      //x軸上的數(shù)據(jù)是動態(tài)的,所以我作為參數(shù)傳進(jìn)來
            axisLabel: {
                interval: 5,   //x軸間隔多少顯示刻度
                formatter: function (value) {   //顯示時間
                    var date = new Date(value * 1000);
                    var h = (date.getHours() < 10 ? '0' + date.getHours() : date.getHours()) + ':';
                    var m = (date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes());
                    return h + m
                },
                fontSize: 8
            }
        },
        yAxis: {
            x: 'center',
            scale: true,
            type: 'value',
            axisLabel: {
                formatter: function (value) {
                var val = value / 1000000000 + 'G';
                    return val
                }
            }
        },
        series: [{
            type: 'line',
            data: ydata,    //y軸上的數(shù)據(jù)也是動態(tài)的,也作為參數(shù)傳進(jìn)來
            symbol: 'none',
            lineStyle: {
                width: 1
            }
        }]
    };
    chart.setOption(option)
}

寫page的一些方法

Page({
    data: {
        ecOne: {
            lazyLoad: true
        },
        ecTwo: {
            lazyLoad: true
        },
        timer:''                 //因為我要實時刷新,所以設(shè)置了個定時器
    },
    onLoad: function (options) {
        var _this = this;
        this.getOneOption();
        this.getTwoOption();
        this.setData({                    //每隔一分鐘刷新一次
            timer: setInterval(function () {
                    _this.getOneOption();
                    _this.getTwoOption();
                }, 60000)
        })
    },
    onReady: function () {               //這一步是一定要注意的
        this.oneComponent = this.selectComponent('#mychart-one');  
        this.twoComponent = this.selectComponent('#mychart-two');
    },
    onUnload: function () {
        clearInterval(this.data.timer)
    },
    init_one: function (xdata, ydata) {           //初始化第一個圖表
        this.oneComponent.init((canvas, width, height) => {
            const chart = echarts.init(canvas, null, {
                width: width,
                height: height
            });
            setOption(chart, xdata, ydata)
            this.chart = chart;
            return chart;
        });
    },
    init_two: function (xdata, ydata) {        //初始化第二個圖表
        this.storagemaxComponent.init((canvas, width, height) => {
            const chart = echarts.init(canvas, null, {
                width: width,
                height: height
            });
            setOption(chart, xdata, ydata)
            this.chart = chart;
            return chart;
        });
    },
    getOneOption: function () {        //這一步其實就要給圖表加上數(shù)據(jù)
        var _this = this;
        wx.request({
            url: 'https://xxxxxxx.com',    //你請求數(shù)據(jù)的接口地址
            method: 'POST',
            header: {
                "Content-Type": "application/json"
            },
            data: {               //傳的參數(shù),這些都不用多說了吧
                id:xxxx
            },
            success:function(res){
     //我這里就假設(shè)res.xdata和res.ydata是我們需要的數(shù)據(jù),即在x軸和y軸展示的數(shù)據(jù),記住一定是數(shù)組哦!
                _this.init_one(res.xdata,res.ydata)
            }
        })  
    },
    //第二個圖表也是一樣的處理
    getTwoOption: function (){  
        var _this = this;
        wx.request({
            url: 'https://xxxxxxx.com',    //你請求數(shù)據(jù)的接口地址
            method: 'POST',
            header: {
                "Content-Type": "application/json"
            },
            data: {                       //傳的參數(shù),這些都不用多說了吧
                id:xxxx
            },
            success:function(res){
                _this.init_two(res.xdata,res.ydata)
            }
        })  
    }
})

好了,大概步驟就是這樣,反正是需要動態(tài)變化就當(dāng)做參數(shù)傳進(jìn)去,我這里在onUnload中清除了定時器,因為不清楚的話,你跳轉(zhuǎn)到別的頁面,你會發(fā)現(xiàn)還會一直請求,所以就要在離開這個頁面之前清除定時器,也不是啥技術(shù)大牛,如果有更好的方法,盼望大神多多指正咯!哈哈哈

總結(jié)

到此這篇關(guān)于微信小程序+ECharts實現(xiàn)動態(tài)刷新的文章就介紹到這了,更多相關(guān)微信小程序+ECharts動態(tài)刷新內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 在js代碼拼接dom對象到頁面上的模板總結(jié)

    在js代碼拼接dom對象到頁面上的模板總結(jié)

    今天小編就為大家分享一篇關(guān)于在js代碼拼接dom對象到頁面上的模板總結(jié),小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • typescript 將數(shù)組清空的方法實現(xiàn)

    typescript 將數(shù)組清空的方法實現(xiàn)

    在開發(fā)應(yīng)用程序時,數(shù)組常用于存儲多個元素(如數(shù)字、字符串、對象等),然而,在某些場景下,你可能需要將數(shù)組清空,本文主要介紹了typescript 將數(shù)組清空的方法實現(xiàn),感興趣的可以了解一下
    2024-08-08
  • js加減乘除丟失精度問題解決方法

    js加減乘除丟失精度問題解決方法

    在javascript中,帶小數(shù)的數(shù)據(jù)運算時總會出現(xiàn)好多位小數(shù).這是因為在javascript中浮點數(shù)的計算是以2進(jìn)制計算的
    2014-05-05
  • JavaScript DOM 學(xué)習(xí)總結(jié)(五)

    JavaScript DOM 學(xué)習(xí)總結(jié)(五)

    當(dāng)頁面加載時,瀏覽器會創(chuàng)建頁面的文檔對象模型(Document Object Model)。文檔對象模型定義訪問和處理HTML文檔的標(biāo)準(zhǔn)方法,本篇文章給大家介紹javascript dom 學(xué)習(xí)總結(jié)(五),感興趣的朋友一起學(xué)習(xí)吧
    2015-11-11
  • IE的fireEvent方法概述及應(yīng)用

    IE的fireEvent方法概述及應(yīng)用

    IE中提供了一個fireEvent方法大概就是觸發(fā)某個事件發(fā)生的意思,以為是和onclick()一樣,看來是我自已為是了,有時間還要多看看javascript的細(xì)節(jié)啊,廣大網(wǎng)友也是啊
    2013-02-02
  • javascript sort()對數(shù)組中的元素進(jìn)行排序詳解

    javascript sort()對數(shù)組中的元素進(jìn)行排序詳解

    在本篇文章里小編給大家整理是一篇關(guān)于javascript sort()對數(shù)組中的元素進(jìn)行排序的相關(guān)知識點內(nèi)容,需要的朋友們學(xué)習(xí)下。
    2019-10-10
  • js實現(xiàn)自動播放勻速輪播圖

    js實現(xiàn)自動播放勻速輪播圖

    這篇文章主要介紹了js實現(xiàn)自動播放勻速輪播圖,帶勻速運動函數(shù)封裝,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • JS判斷字符串是否全為空的兩種方式

    JS判斷字符串是否全為空的兩種方式

    當(dāng)我們需要判斷用戶輸入的是否全是空格,或用戶在不輸入內(nèi)容的情況下使用回車發(fā)送,此時我們?nèi)绻枨髢?nèi)容不能為空,常規(guī)判斷無法識別,空格本身也有l(wèi)ength,這個時候就可使用到下列兩種方式
    2023-10-10
  • JS實現(xiàn)動態(tài)無縫輪播

    JS實現(xiàn)動態(tài)無縫輪播

    這篇文章主要為大家詳細(xì)介紹了JS實現(xiàn)動態(tài)無縫輪播,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-01-01
  • layui問題之模擬table表格中的選中按鈕選中事件的方法

    layui問題之模擬table表格中的選中按鈕選中事件的方法

    今天小編就為大家分享一篇layui問題之模擬table表格中的選中按鈕選中事件的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09

最新評論