WeChatミニプログラムの基本チュートリアル:Echartの使用

WeChatミニプログラムの基本チュートリアル:Echartの使用

序文

まずは最終的な効果を見てみましょう。私が自分で作った小さなデモです。

まずEChartsの公式サイトにアクセスして公式サイトのアドレスをダウンロードしてください

上記の URL からコードをダウンロードし、ec-canvas ファイルを自分のプロジェクトにコピーします。

ツールフォルダに入れました。インポートする際はパスに注意してください。

2. 使用

次に、必要なページにインポートしてjsonに追加します。パスechart.jsonに注意してください。

"コンポーネントの使用": {
    "タブ":"../../component/tabs/tab",
    "ec-canvas":"../../tools/ec-canvas/ec-canvas"
  },

3 レンダリング

まず、シンプルなレイアウトとスタイルechart.wxmlを作成します。

<view class="echart">
 <tab active-tab="{{activeTab}}" period-list="{{periodList}}" bind:changePeriodType='changePeriodType'></tab>
 <view class="echart-position">
    <ec-canvas id="mychart-dom-bar" canvas-id="mychart-bar"></ec-canvas>
 </ビュー>
 
</ビュー>

スタイル echart.wxss

.echart-position {
    位置:相対;
    高さ: 280px;
    オーバーフロー:非表示;
  }

チャート

まず紹介する

'../../tools/ec-canvas/echarts' から * を echarts としてインポートします。
関数setOption(チャート,データ){
    var オプション = {
        タイトル:
            文章: ''
        },
        ツールチップ: {
            トリガー: 'アイテム'
        },
        伝説: {
            データ: []
        },
        シリーズ: [{
            名前: ''、
            タイプ: 'パイ'、
            半径: ['40%', '70%'],
            ラベルの重複を避ける: false,
            ラベル: {
                表示: 偽、
                位置: '中央'
            },
            強調:
                ラベル: {
                    表示: true、
                    フォントサイズ: '40',
                    フォントの太さ: '太字'
                }
            },
            ラベル行:
                表示:偽
            },
            データ: [
               ...データ
            ]
        }]
    };
    chart.setOption(オプション);
    リターンチャート;
}
ページ({
    データ: {
        期間リスト: [
            {
                id: '結果',
                テキスト: 「支出」
            },
            {
                id: '収入',
                テキスト: '収入'
            },
        ]、
        アクティブタブ: '結果',
        echartsData: null, //echartsデータ},
    // 収入と支出の切り替えイベント changePeriodType(e) {
        console.log(e, '<=収入支出切り替えイベント')
        this.setData({
            アクティブタブ: e.detail.params.type
        })
        // リストを再クエリします this.getEchartData();
    },
    // 収入と支出のデータを照会する getEchartData() {
        wx.cloud.database().collection('spendD').where({
            タイプ: this.data.activeTab == 'outcome' ? 0 : 1
        }).get().then(res => {
            calcResult = this.handleOriginData(res.data); とします。
            this.setData({
                echartsData:calcResult
            })
            this.init_one(計算結果)
        })
    },
    ハンドルオリジンデータ(配列) {
        結果 = [] とします。
        obj = {} とします
        配列.forEach(項目 => {
            if (!obj[item.name]) {
                obj[アイテム名] = 0;
            }
            obj[item.name] += Number(item.amount);
        })

        for(let key in obj){
            temp = {} とします。
            temp['name'] = キー;
            temp['値'] = obj[キー];
            結果をプッシュします(temp);
        }
        console.log(結果、'結果')
        結果を返す
    },
    /**
   * ライフサイクル機能 - ページの読み込みをリッスンする*/

  init_one: function (data) { // チャートを初期化します this.echartComponent.init((canvas, width, height) => {
        const chart = echarts.init(canvas, null, {
            幅: 幅、
            高さ: 高さ
        });
        setOption(チャート、データ)
        this.chart = チャート;
        リターンチャート;
    });
},
    onLoad: 関数 (オプション) {
        this.getEchartData()
    },

    /**
     * ライフサイクル関数 - ページの初期レンダリングの完了を待機します*/
    onReady: 関数 () {
        this.echartComponent = this.selectComponent('#mychart-dom-bar');  
    },

})

ピットを見つけるためのヒント:チュートリアルに従って構成された画像が期待どおりにならない場合は、次のスタイルを追加することに注意してください

要約する

WeChat ミニプログラムでの echart の使用に関する基本的なチュートリアルに関するこの記事はこれで終わりです。WeChat ミニプログラムでの echart の使用に関するより関連性の高いコンテンツについては、123WORDPRESS.COM で以前の記事を検索するか、以下の関連記事を引き続き参照してください。皆様が今後も 123WORDPRESS.COM を応援してくれることを願っています。

以下もご興味があるかもしれません:
  • vue で vue-echarts-v3 を使用するサンプルコード
  • Echarts を使用して棒グラフを描く vue の詳細な説明
  • vue2 vue3 での Echarts の詳細な使用方法
  • Django での視覚化に echarts を使用する練習
  • ネイティブechartとvue-echartの使用に関する詳細な説明

<<:  Windows 8 での ssh コマンドの使用記録

>>:  MySQL 8.0.13 のインストールと設定方法のグラフィックチュートリアル

推薦する

CSS の記述基準と順序を共有する [すべての人に使用を推奨]

CSSの記述順序1. 位置属性(位置、上、右、z-index、表示、フロートなど) 2. サイズ(...

Linuxシステムはポート3306、8080などを外部に開放します。ファイアウォール設定の詳しい説明

多くの場合、Linux システムに Web サービス アプリケーション (Tomcat、Apache...

Dockerコンテナのディスクがいっぱいになった場合の状況のまとめ

序文この記事では、最近私が遭遇した 2 つの状況について説明します。今後、新たな発見があれば追加して...

WeChatアプレットはウォーターフォールフローのページングスクロール読み込みを実装します

この記事では、WeChatアプレットのウォーターフォールフローページングスクロールロードを実装するた...

一般的な Linux ディストリビューションのミラーソース構成の概要

最近 Linux を研究していて、いくつかの Linux ディストリビューションを試してみましたが、...

Nginx 1つのドメイン名で複数のプロジェクトにアクセスする方法の例

背景最近、複数のプロジェクトを展開する際に、1 つのドメイン名で複数のプロジェクトにアクセスする方法...

ファイアウォールの iptables 戦略を使用して Linux サーバー上のポートを転送する方法

2つの異なるサーバー間の転送ポート転送を有効にするまず、デフォルトでは無効になっている IP 転送機...

クラウドサーバーを購入し、Alibaba Cloud に Pagoda Panel をインストールする手順

アリババクラウドがサーバーを購入クラウドサーバーを購入し、サーバーバージョンとしてcentos 7....

MySQLにおけるSQLの実行順序についてのちょっとした質問

今日、仕事中に左結合に関するSQLの問題に遭遇しました。後で解決しましたが、この問題を通じてSQLの...

MySQL テーブル内の重複データを検索して削除する方法の概要

時々、データベース テーブルに重複したデータが大量に保存されます。これらの重複データはリソースを浪費...

使用状況分析を備えたMySQL

持つことの使用法having 句を使用すると、グループ化後にさまざまなデータをフィルター処理できます...

Mysql テーブルで利用可能な最小 ID 値を照会する方法

今日、研究室のプロジェクトを見ていたとき、私にとって「難しい」問題に遭遇しました。実は、それは私があ...

シンプルなドラッグ効果を実現するJavaScript

この記事では、簡単なドラッグ効果を実現するためのJavaScriptの具体的なコードを参考までに紹介...

Nginx設定ファイルの詳細な説明

Nginx の主な設定ファイルは nginx.conf で、グローバル ブロック、イベント ブロック...

IE6のバグと修正は予防戦略です

元記事:究極の IE6 チートシート: 25 以上の Internet Explorer 6 のバグ...