検索
ホームページバックエンド開発PHPチュートリアルPHP と Vue.js で動的に更新される水平統計グラフを実装する方法

PHP と Vue.js で動的に更新される水平統計グラフを実装する方法

PHP および Vue.js で動的に更新される水平統計グラフを実装する方法

前書き:
統計グラフは、データ視覚化の重要なコンポーネントの 1 つです。 Web 開発では、PHP がデータの保存と計算を処理するバックエンド言語として使用され、Vue.js がデータとページの対話を表示するフロントエンド フレームワークとして使用されます。この記事では、PHP と Vue.js を組み合わせて、動的に更新される水平統計グラフを実装する方法を紹介します。

1. 準備
開始する前に、次の環境をインストールして構成する必要があります:

  1. サーバー環境: Apache などの PHP コードを実行できるサーバーを構築します。そしてNginxは待ちます。
  2. データベース: MySQL またはその他のリレーショナル データベースを使用します。

2. バックエンド開発

  1. データベース テーブルの作成
    まず、統計データを保存するデータベース テーブルを作成する必要があります。 「statistics」という名前のテーブルには、id と value の 2 つのフィールドが含まれています。
CREATE TABLE statistics (
    id INT AUTO_INCREMENT PRIMARY KEY,
    value INT
);
  1. バックエンド インターフェイス
    PHP では、バックエンド インターフェイスを記述することでフロントエンドに提供できます。 「api.php」という名前のファイルを作成し、次のコードを記述します。
<?php
// 设置响应头
header('Content-Type: application/json');

// 连接数据库
$db = new PDO('mysql:host=localhost;dbname=your_database;charset=utf8', 'your_username', 'your_password');

// 查询数据
$stmt = $db->query('SELECT * FROM statistics');
$statistics = $stmt->fetchAll(PDO::FETCH_ASSOC);

// 返回数据
echo json_encode($statistics);

上記のコードは、PDO を通じてデータベースに接続し、統計データをクエリし、クエリ結果をフロントエンドに返します。 JSON形式で。

3. フロントエンド開発

  1. ページ構造
    フロントエンドで Vue.js を使用してページをレンダリングし、データを処理するには、HTML ファイルを作成する必要があります。 Vue.js CDN リンクを紹介します。具体的なコードは次のとおりです。
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>动态更新的水平统计图表</title>
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
</head>
<body>
    <div id="app">
        <canvas id="chart"></canvas>
    </div>
    <script src="app.js"></script>
</body>
</html>
  1. JavaScript コード
    同じディレクトリに「app.js」という名前のファイルを作成し、次のコードを記述します。
    new Vue({
        el: '#app',
        data: {
            chartData: []
        },
        mounted() {
            this.getChartData();
        },
        methods: {
            getChartData() {
                fetch('api.php')
                    .then(response => response.json())
                    .then(data => {
                        this.chartData = data.map(item => item.value);
                        this.renderChart();
                    })
                    .catch(error => console.error(error));
            },
            renderChart() {
                var ctx = document.getElementById('chart').getContext('2d');
                new Chart(ctx, {
                    type: 'horizontalBar',
                    data: {
                        labels: ['1月', '2月', '3月', '4月', '5月', '6月'],
                        datasets: [{
                            label: '销售统计',
                            data: this.chartData,
                            backgroundColor: 'rgba(0,123,255,0.5)'
                        }]
                    },
                    options: {
                        scales: {
                            yAxes: [{
                                ticks: {
                                    beginAtZero: true
                                }
                            }]
                        }
                    }
                });
            }
        }
    });
  2. 上記のコードは、Vue.js を使用して Vue インスタンスを作成し、マウントされたフック関数で getChartData メソッドを呼び出し、フェッチを通じて GET リクエストを送信してバックエンド インターフェイスから返されたデータを取得し、そのデータを chartData に割り当てます。そして、 renderChart メソッドを呼び出して統計を表示します。

4. テスト実行

ブラウザで HTML ファイルを開くと、動的に更新される水平統計グラフが表示されます。追加する必要がある新しい統計データがある場合は、バックエンド インターフェイスを呼び出すことでデータを追加でき、フロントエンドが自動的に最新のデータを取得してグラフを更新します。


結論:

この記事では、動的に更新される水平統計グラフを PHP と Vue.js で実装する方法を紹介します。バックエンド インターフェイスを通じてデータベースから統計データを取得し、Vue.js を使用してフロントエンドにデータを表示し、グラフの動的な更新を実装します。この実装方法は、多くの実際のデータ視覚化シナリオに適用して、ユーザー エクスペリエンスとデータ表示効果を向上させることができます。

以上がPHP と Vue.js で動的に更新される水平統計グラフを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
php怎么把负数转为正整数php怎么把负数转为正整数Apr 19, 2022 pm 08:59 PM

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

php怎么实现几秒后执行一个函数php怎么实现几秒后执行一个函数Apr 24, 2022 pm 01:12 PM

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php怎么除以100保留两位小数php怎么除以100保留两位小数Apr 22, 2022 pm 06:23 PM

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

php怎么根据年月日判断是一年的第几天php怎么根据年月日判断是一年的第几天Apr 22, 2022 pm 05:02 PM

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php字符串有没有下标php字符串有没有下标Apr 24, 2022 am 11:49 AM

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php怎么读取字符串后几个字符php怎么读取字符串后几个字符Apr 22, 2022 pm 08:31 PM

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

php怎么替换nbsp空格符php怎么替换nbsp空格符Apr 24, 2022 pm 02:55 PM

方法:1、用“str_replace("&nbsp;","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\&nbsp\;||\xc2\xa0)/","其他字符",$str)”语句。

php怎么判断有没有小数点php怎么判断有没有小数点Apr 20, 2022 pm 08:12 PM

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール