ホームページ ウェブフロントエンド jsチュートリアル タイプごとに同じIDで配列オブジェクトをマージし、JavaScriptを使用して金額を割り当てる方法は?

タイプごとに同じIDで配列オブジェクトをマージし、JavaScriptを使用して金額を割り当てる方法は?

Apr 04, 2025 pm 03:00 PM
red

タイプごとに同じIDで配列オブジェクトをマージし、JavaScriptを使用して金額を割り当てる方法は?

この記事では、JavaScriptを使用して配列を処理し、同じIDを持つオブジェクトを新しいオブジェクトにマージし、異なるタイプ(朝食、中国語、夕食)に応じて異なるフィールドに量を割り当てる方法について説明します。

それぞれがidjine (量)、およびtype (タイプ)フィールドを持つ複数のオブジェクトの配列があるとします。目標は、これらのデータを別の形式に変換することです。各idに対応するデータが1つのtypeにマージされ、 jine値はjine1 (朝食)、 jine2 (中国料理)、およびjine3 (ディナー)フィールドに割り当てられます。

生データ:

 const list = [
    {id: "202301"、jine:23、type: "ディナー"}、
    {id: "202301"、jine:87.5、type: "Breakfast"}、
    {id: "202301"、jine:1065.5、タイプ: "中国料理"}、
    {id: "202302"、jine:10、type: "ディナー"}、
    {id: "202302"、jine:181.5、type: "Breakfast"}、
    {id: "202302"、jine:633.5、タイプ: "中華料理"}
];
ログイン後にコピー

ターゲット形式:

 const expectslist = [
    {id: "202301"、jine1:87.5、jine2:1065.5、jine3:23}、
    {id: "202302"、jine1:181.5、jine2:633.5、jine3:10}
];
ログイン後にコピー

これを達成するために、 reduceメソッドを使用して配列を反復し、結果を保存する新しいオブジェクトを作成できます。

解決:

 const result = object.values(list.reduce((acc、curr)=> {
    if(!acc [curr.id]){
        acc [curr.id] = {id:curr.id、jine1:0、jine2:0、jine3:0};
    }
    if(curr.type === 'Breakfast')acc [curr.id] .jine1 = curr.jine;
    if(curr.type === 'chinese food')acc [curr.id] .jine2 = curr.jine;
    if(curr.type === 'dinner')acc [curr.id] .jine3 = curr.jine;
    ACCを返します。
}、{}));

console.log(result); //ターゲット形式の出力配列
ログイン後にコピー

このコードは、最初にreduceメソッドを使用して元の配列をオブジェクトに変換します。キーはidで、値はjine1jine2 、およびjine3を含むオブジェクトです。次に、 Object.valuesメソッドを使用して、オブジェクトを配列に変換します。 reduceメソッドでは、現在のidaccに存在するかどうかを確認します。存在しない場合は、新しいオブジェクトを作成し、 typeに応じて対応するフィールドにjine値を割り当てます。

この方法は、 Object.groupByの使用を回避し、メソッドfind 、コードの読みやすさと効率を改善し、データのマージと量の割り当てをより直接処理します。また、 findメソッドがundefined返される場合がある場合に対処する必要がないため、より堅牢です。

以上がタイプごとに同じIDで配列オブジェクトをマージし、JavaScriptを使用して金額を割り当てる方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Centos RedisでLUAスクリプト実行時間を構成する方法 Centos RedisでLUAスクリプト実行時間を構成する方法 Apr 14, 2025 pm 02:12 PM

Centosシステムでは、Redis構成ファイルを変更するか、Redisコマンドを使用して悪意のあるスクリプトがあまりにも多くのリソースを消費しないようにすることにより、LUAスクリプトの実行時間を制限できます。方法1:Redis構成ファイルを変更し、Redis構成ファイルを見つけます:Redis構成ファイルは通常/etc/redis/redis.confにあります。構成ファイルの編集:テキストエディター(VIやNANOなど)を使用して構成ファイルを開きます:sudovi/etc/redis/redis.conf luaスクリプト実行時間制限を設定します。

HDFSでCentosを構成するために必要な手順 HDFSでCentosを構成するために必要な手順 Apr 14, 2025 pm 06:42 PM

CENTOSシステムにHadoop分散ファイルシステム(HDFS)を構築するには、複数のステップが必要です。この記事では、簡単な構成ガイドを提供します。 1.初期段階でJDKをインストールする準備:すべてのノードにJavadevelopmentKit(JDK)をインストールすると、バージョンはHadoopと互換性がある必要があります。インストールパッケージは、Oracleの公式Webサイトからダウンロードできます。環境変数構成: /etc /プロファイルファイルを編集し、JavaおよびHadoop環境変数を設定して、システムがJDKとHadoopのインストールパスを見つけることができるようにします。 2。セキュリティ構成:SSHパスワードなしログインSSHキーを生成する:各ノードでSSH-KeyGenコマンドを使用する

DebianがHadoopデータ処理速度を改善する方法 DebianがHadoopデータ処理速度を改善する方法 Apr 13, 2025 am 11:54 AM

この記事では、DebianシステムのHadoopデータ処理効率を改善する方法について説明します。最適化戦略では、ハードウェアのアップグレード、オペレーティングシステムパラメーターの調整、Hadoop構成の変更、および効率的なアルゴリズムとツールの使用をカバーしています。 1.ハードウェアリソースの強化により、すべてのノードが一貫したハードウェア構成、特にCPU、メモリ、ネットワーク機器のパフォーマンスに注意を払うことが保証されます。高性能ハードウェアコンポーネントを選択することは、全体的な処理速度を改善するために不可欠です。 2。オペレーティングシステムチューニングファイル記述子とネットワーク接続:/etc/security/limits.confファイルを変更して、システムによって同時に開くことができるファイル記述子とネットワーク接続の上限を増やします。 JVMパラメーター調整:Hadoop-env.shファイルで調整します

DICR/YII2-GOOGLEを使用して、Yii2にGoogle APIを統合します DICR/YII2-GOOGLEを使用して、Yii2にGoogle APIを統合します Apr 18, 2025 am 11:54 AM

vProcesserazrabotkiveb-Enclosed、する、するまみ、するまで。 leavallysumballancefriablancefaumdoptomatification、čtokazalovnetakprosto、kakaožidal.posenesko

スロークエリログを設定する方法Centos Redis スロークエリログを設定する方法Centos Redis Apr 14, 2025 pm 04:54 PM

CENTOSシステムのRedisスロークエリログを有効にして、パフォーマンスの診断効率を改善します。次の手順では、構成をガイドします。ステップ1:最初にRedis構成ファイルを見つけて編集し、通常は/etc/redis/redis.confにあるRedis構成ファイルを見つけます。次のコマンドで構成ファイルを開きます:sudovi/etc/redis/redis.confステップ2:構成ファイルでスロークエリログパラメーターを調整し、次のパラメーターを見つけて変更します:#slow query-log-log-slower-slower-than10000#スロークエリのエントリの最大数

Redisキャッシュソリューションを使用して、製品ランキングリストの要件を効率的に実現する方法は? Redisキャッシュソリューションを使用して、製品ランキングリストの要件を効率的に実現する方法は? Apr 19, 2025 pm 11:36 PM

Redisキャッシュソリューションは、製品ランキングリストの要件をどのように実現しますか?開発プロセス中に、多くの場合、ランキングの要件に対処する必要があります。

HDFS Configuration Centosで変更するには、どのファイルが必要ですか? HDFS Configuration Centosで変更するには、どのファイルが必要ですか? Apr 14, 2025 pm 07:27 PM

Hadoop分散ファイルシステム(HDFS)をCentOSに構成する場合、次のキー構成ファイルを変更する必要があります。Core-Site.xml:Fs.DefaultFS:HDFS:// LocalHost:9000などのHDFSのデフォルトファイルシステムアドレスを指定します。 hadoop.tmp.dir:Hadoop一時ファイルのストレージディレクトリを指定します。 hadoop.proxyuser.root.hosts and hadoop.proxyuser.ro

CENTOSでHDFSファイルシステムを使用するためのヒント CENTOSでHDFSファイルシステムを使用するためのヒント Apr 14, 2025 pm 07:30 PM

CENTOSシステムの下でのHDFSファイルシステム用のインストール、構成、および最適化ガイドこの記事では、CENTOSシステムにHadoop分散ファイルシステム(HDFS)をインストール、構成、最適化する方法をガイドします。 HDFSのインストールと構成Java環境のインストール:最初に、適切なJava環境がインストールされていることを確認してください。 /etc/プロフィールファイルを編集し、以下を追加して、/usr/lib/java-1.8.0/jdk1.8.0_144を実際のJavaインストールパスで置き換えます:Exportjava_home =/usr/lib/Java-1.8.0/JDK1.8.0_144EXPORTPATH = $ J

See all articles