ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript ピボット テーブルでのメモリ管理の最適化: ベスト プラクティスとヒント

JavaScript ピボット テーブルでのメモリ管理の最適化: ベスト プラクティスとヒント

王林
リリース: 2024-08-22 22:37:03
オリジナル
566 人が閲覧しました

TL;DR: 大規模なデータセットでスムーズなパフォーマンスを確保するための仮想スクロール、データ処理、メモリ プロファイリングに関するヒントなど、Syncfusion JavaScript ピボット テーブルでメモリ管理を最適化するためのベスト プラクティスを学びます。

Web アプリケーションの最適化、特に大規模なデータセットや複雑なデータの視覚化を処理する場合、メモリ管理は非常に重要です。

Syncfusion JavaScript ピボット テーブルは、データを分析および表示するための強力なツールです。ただし、効率的に実行するには、効果的なメモリ管理戦略が必要です。

このブログでは、JavaScript ピボット テーブルでのメモリ使用量を最適化し、よりスムーズなパフォーマンスと優れたユーザー エクスペリエンスを実現するためのベスト プラクティスとヒントを取り上げます。

メモリの課題を理解する

大規模なデータセットを操作する場合、ピボット テーブルは大量のメモリを消費し、レンダリング時間の遅さ、インタラクションの遅れ、ブラウザのクラッシュの可能性などのパフォーマンスの問題を引き起こす可能性があります。主な課題は次のとおりです。

  • 大規模なデータ セット – 数千の行と列をレンダリングすると、メモリ リソースが過剰になる可能性があります。
  • 複雑な計算 – リアルタイム データの集計と計算にはリソースが大量に消費される可能性があります。
  • 頻繁な更新 – 頻繁に更新される動的データは、適切に管理されないとメモリ リークを引き起こす可能性があります。

メモリ消費量のテスト結果

クライアント エンジン モードとサーバー エンジン モードを介して JSON データを JavaScript ピボット テーブルにバインドすることにより、Chrome ブラウザでテスト結果を取得しました。次の表は、100K および 100 万の一意のデータセット数を Syncfusion JavaScript ピボット テーブルにバインドするために消費されるブラウザー メモリを示しています。

Unique dataset count

Rendering mode

Memory consumption (In MB)

100K

Client

96.5

Server

19.5

1 million

Client

792

Server

20.4

一意のデータセット数 レンダリングモード メモリ消費量 (MB 単位) 100,000 クライアント 96.5 サーバー 19.5 100万 クライアント 792 サーバー 20.4 テーブル>

次の画像は、クライアント側エンジンを使用した場合の Chrome ブラウザの 100K および 100 万のデータ ポイントのメモリ消費量を示しています。

100K データ:

Optimize Memory Management in JavaScript Pivot Table: Best Practices and Tips

Chrome ブラウザでの 100K データのメモリ使用量

100 万データ:

Memory usage for 1 million data in the Chrome browser

Chrome ブラウザでの 100 万件のデータのメモリ使用量

注: メモリ使用量は、ピボット レポートの構成と有効になっている機能によって異なる場合があります。

JavaScript ピボット テーブルのメモリ管理のベスト プラクティス

JavaScript ピボット テーブル コンポーネントのメモリ管理を最適化するためのベスト プラクティスをいくつか見てみましょう:

仮想スクロールまたはページング

大きなデータのロードは、メモリ使用量が増加する主な原因の 1 つです。仮想スクロールまたはページングを実装すると、ピボット テーブルのすべての行と列をロードするのではなく、現在のビューポートのデータのみをロードし、残りのデータをオンデマンドでロードできるようになります。これにより、初期ロード時間とメモリ使用量が削減されます。

var pivotGridObj = new ej.pivotview.PivotView({
    enableVirtualization: true, // Enable virtualization to load data as needed.
    enablePaging: true, // Enable paging and page settings to load data as needed.
    pageSettings: {
        rowPageSize: 10,
        columnPageSize: 5,
        currentColumnPage: 1,
        currentRowPage: 1
    },
    dataSourceSettings: {
        dataSource: largeDataSet,
        columns: [{ name: 'Product' }],
        rows: [{ name: 'Country' }],
        values: [{ name: 'Sales', caption: 'Total Sales' }]
    }
});
pivotGridObj.appendTo('#PivotView');
ログイン後にコピー

未使用のインスタンスを破棄する

JavaScript ピボット テーブル インスタンスが不要になったら、メモリを解放するために適切に破棄します。

次のコード例を参照してください。

function destroyPivotTable() {
    if (pivotGridObj) {
        pivotGridObj.destroy(); // Method used to destroy the Pivot Table.
        pivotGridObj = null;
    }
}
ログイン後にコピー

データ処理を最適化する

可能な限りサーバー側エンジンでデータを前処理することで、リアルタイムの計算と集計の数を減らします。

var pivotObj = new ej.pivotview.PivotView({
    dataSourceSettings: {
        url: 'https://localhost:44350/api/pivot/post', // Preprocess data using the server-side engine to minimize client-side processing.
        mode: 'Server',
        rows: [{
            name: 'ProductID', caption: 'Product ID'
        }],
        columns: [{
            name: 'Year', caption: 'Production Year'
        }],
        values: [
            { name: 'Sold', caption: 'Units Sold' },
            { name: 'Price', caption: 'Sold Amount' }
        ],
    }
    //Other codes here...
});
pivotObj.appendTo('#PivotTable');
ログイン後にコピー

ピボットテーブルのレンダリングを最適化する

効率的なレンダリング手法を使用して、ピボット テーブルのメモリ使用量を最小限に抑えます。これには、不必要な再レンダリングを回避し、ピボット テーブルの UI が変更された場合にのみ更新することが含まれます。必要に応じて、元々ピボット テーブルを更新するために使用されていたパブリック関数を使用します。それ以外の場合は、プロパティ バインディングを通じてピボット テーブルを更新します。

たとえば、dataSource プロパティと dataSourceSettings プロパティを使用して、行、列、値、フィルター軸などのデータまたはバインドされたフィールド設定を動的に変更できます。これにより、ピボット テーブルが更新されます。

次のコード例を参照してください。

var pivotObj = new ej.pivotview.PivotView({
    dataSourceSettings: {
        dataSource: window.pivotData, // Assign the data to the Pivot Table.
        rows: [{
            name: 'ProductID', caption: 'Product ID'
        }],
        columns: [{
            name: 'Year', caption: 'Production Year'
        }],
        values: [
            { name: 'Sold', caption: 'Units Sold' },
            { name: 'Price', caption: 'Sold Amount' }
        ],
    }
    //Other codes here...
});
pivotObj.appendTo('#PivotTable');

var applyBtn = new ej.buttons.Button({
        isPrimary: true
});
applyBtn.appendTo('#update');
document.getElementById(update'').onclick = function () {
     // Set the modified/updated data to the Pivot Table using the ‘dataSource’ property.
     pivotObj.dataSourceSettings.datasource = updatedPivotData;

     // Set the formatting to the value field “Price” using the ‘formatSettings’ property within the ‘dataSourceSettings’.
     pivotObj.dataSourceSettings.formatSettings = [{ name: 'Price', format: 'C0' }];
}
ログイン後にコピー

定期的なメモリプロファイリング

アプリのメモリ使用量を定期的にプロファイリングして、潜在的なリークを特定し、パフォーマンスを向上させます。メモリプロファイリングに推奨されるツールは次のとおりです:

  • Chrome DevTools: パフォーマンス タブと メモリ タブを使用して、メモリ使用率を監視し、リークを検出します。

  • Firefox 開発者ツール: Chrome DevTools と同様に、メモリ消費量に関する正確な洞察を提供します。

GitHub リファレンス

また、JavaScript Pivot Table GitHub デモのメモリ管理の最適化も参照してください。ここでは、クライアント側エンジンを使用してパフォーマンスとメモリの統計を収集します。

結論

読んでいただきありがとうございます!このブログでは、Syncfusion JavaScript ピボット テーブルでメモリ管理を最適化する方法について説明しました。効率的なデータ処理、適切なインスタンスの破棄、および仮想化技術を組み合わせて適用することで、大規模なデータセットであってもピボット テーブルがシームレスに実行され、ユーザーにスムーズで応答性の高いエクスペリエンスを提供できます。

これらのベスト プラクティスを実装すると、メモリ使用率を効果的に管理できるようになり、パフォーマンスが向上し、全体的なユーザー エクスペリエンスが向上します。これらのヒントを試して、以下のコメントセクションにフィードバックを残してください!

すでに Syncfusion ユーザーである場合は、Essential Studio の最新バージョンが「ライセンスとダウンロード」ページから入手できます。新規ユーザーには、コンポーネントのすべての機能を試していただくための 30 日間の無料トライアルを提供しています。

さらにサポートが必要な場合は、サポート フォーラム、サポート ポータル、またはフィードバック ポータルからお問い合わせください。私たちはいつでもお手伝いいたします!

関連ブログ

  • ピボット テーブル集計による生データの変換
  • JavaScript で OLAP データを使用してピボット テーブルを作成する方法
  • ピボット テーブルを使用して、Web アプリケーションでデータを範囲に簡単にグループ化します
  • Web アプリを不正な JavaScript 実行から保護するための 5 つのテクニック

以上がJavaScript ピボット テーブルでのメモリ管理の最適化: ベスト プラクティスとヒントの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:dev.to
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート