ホームページ ウェブフロントエンド jsチュートリアル JavaScript の日付に確実に月を追加する方法

JavaScript の日付に確実に月を追加する方法

Dec 04, 2024 pm 01:21 PM

How to Reliably Add Months to a JavaScript Date?

JavaScript の日付に月を追加する方法

年ロールを処理したい場合、JavaScript の日付に月を追加するのは難しい作業になる可能性があります- オーバーとさまざまな月の長さを正しく設定します。プロセスを簡素化するには、事前に構築された関数の利用を検討してください。

次の JavaScript 関数は、クリーンで簡単なソリューション (このソースから引用) を提供します。

関数: addMonths(日付, months)

説明:

  • JavaScript の Date オブジェクトを入力 (日付) として受け取ります。
  • 指定された月数 (月) を追加します
  • 年のロールオーバーを処理し、さまざまな月の長さに合わせて調整します。
  • 変更された日付を持つ新しい Date オブジェクトを返します。

使用例:

// Add 12 months to 29 Feb 2016 -> 28 Feb 2017
console.log(addMonths(new Date(2016, 1, 29), 12).toString());

// Subtract 1 month from 1 Jan 2017 -> 1 Dec 2016
console.log(addMonths(new Date(2017, 0, 1), -1).toString());

// Subtract 2 months from 31 Jan 2017 -> 30 Nov 2016
console.log(addMonths(new Date(2017, 0, 31), -2).toString());

// Add 2 months to 31 Dec 2016 -> 28 Feb 2017
console.log(addMonths(new Date(2016, 11, 31), 2).toString());

出力:

Sat Feb 28 00:00:00 GMT+0000 2017
Sun Dec 01 00:00:00 GMT+0000 2016
Wed Nov 30 00:00:00 GMT+0000 2016
Tue Feb 28 00:00:00 GMT+0000 2017

この関数は、次のタスクを簡素化します。 JavaScript の日付に月を追加すると、複雑な日付計算を必要とせずに信頼できる結果が得られます。

以上がJavaScript の日付に確実に月を追加する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホットAIツール

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

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)

TypeScriptの高度な条件付きタイプ TypeScriptの高度な条件付きタイプ Aug 04, 2025 am 06:32 AM

TypeScriptの高度な条件タイプは、TextEndsu?X:Y Syntaxを介してタイプ間の論理的判断を実装します。そのコア機能は、分散条件タイプ、推測タイプの推論、および複雑なタイプのツールの構築に反映されます。 1.条件付きタイプは、裸の型パラメーターに分散され、string [] | number []を取得するためにtoArrayなどのジョイントタイプを自動的に分割できます。 2.分布を使用してフィルタリングおよび抽出ツールを構築します。除外textendsuを除く除外:t、抽出抽出抽出extract textendsu?t:never、およびnullable filters null/undefined。 3

解決されたダブルチョコレートパズルを生成:データ構造とアルゴリズムのガイド 解決されたダブルチョコレートパズルを生成:データ構造とアルゴリズムのガイド Aug 05, 2025 am 08:30 AM

この記事では、ダブルチョコパズルゲーム用の溶媒があるパズルを自動的に生成する方法を詳細に説明します。効率的なデータ構造 - 境界情報、色、状態を含む2Dグリッドに基づくセルオブジェクトを紹介します。これに基づいて、再帰的なブロック認識アルゴリズム(深さfirst検索と同様)と、それを反復パズル生成プロセスに統合する方法について詳しく説明し、生成されたパズルがゲームのルールを満たし、溶媒があることを確認します。この記事では、サンプルコードを提供し、生成プロセスにおける重要な考慮事項と最適化戦略について説明します。

JavaScriptのクラス構文とは何ですか?プロトタイプとどのように関係していますか? JavaScriptのクラス構文とは何ですか?プロトタイプとどのように関係していますか? Aug 03, 2025 pm 04:11 PM

JavaScriptのクラス構文は、プロトタイプで継承された構文糖です。 1。クラスで定義されるクラスは基本的に関数であり、メソッドはプロトタイプに追加されます。 2。インスタンスは、プロトタイプチェーンを介してメソッドを検索します。 3.静的メソッドはクラス自体に属します。 4。プロトタイプチェーンを介して継承されているが、基礎となる層は依然としてプロトタイプメカニズムを使用している。クラスは、JavaScriptプロトタイプ継承の本質を変えていません。

JavaScriptアレイメソッドのマスタリング:「Map」、 `Filter'、および` Reduce' JavaScriptアレイメソッドのマスタリング:「Map」、 `Filter'、および` Reduce' Aug 03, 2025 am 05:54 AM

JavaScriptの配列メソッドマップ、フィルター、および還元は、明確で機能的なコードを書き込むために使用されます。 1。マップは、配列内の各要素を変換し、摂氏を華氏に変換するなどの新しい配列を返すために使用されます。 2。フィルターは、条件に応じて要素をフィルタリングし、偶数やアクティブユーザーの取得などの条件を満たす新しい配列を返すために使用されます。 3.還元は、頻度の合計やカウントなどの結果を蓄積するために使用され、初期値を提供してアキュムレータに返す必要があります。 3つのいずれも元の配列を変更することはなく、データの処理と変換に適したチェーンで呼び出すことはできません。

JavaScriptを使用してDOM要素からCSSクラスを削除するにはどうすればよいですか? JavaScriptを使用してDOM要素からCSSクラスを削除するにはどうすればよいですか? Aug 05, 2025 pm 12:51 PM

JavaScriptを使用してDOM要素からCSSクラスを削除するための最も一般的で推奨される方法は、クラスリストプロパティのremove()メソッドを使用しています。 1。要素を使用して、単一または複数のクラスを安全に削除するには、クラスが存在しなくてもエラーは報告されません。 2.代替方法は、クラス名プロパティを直接操作し、文字列交換でクラスを削除することですが、定期的なマッチングまたは不適切な空間処理のために問題を引き起こすのは簡単であるため、推奨されません。 3.最初にクラスが存在するかどうかを判断してから、element.classlist.contains()を介して削除できますが、通常は必要ありません。 4.クラスリスト

VercelSPAルーティングとリソースの読み込み:ディープURLアクセスの問題を解決する VercelSPAルーティングとリソースの読み込み:ディープURLアクセスの問題を解決する Aug 13, 2025 am 10:18 AM

この記事の目的は、Vercelにシングルページアプリケーション(SPA)を展開する際に、ディープURLの更新または直接アクセスの原因となる問題を解決することを目的としています。コアは、Vercelのルーティング書き換えメカニズムと相対パスを解析するブラウザの違いを理解することです。 Vercel.jsonを設定してすべてのパスをindex.htmlにリダイレクトし、HTMLの静的リソースの参照方法を修正し、相対パスを絶対パスに変更し、アプリケーションがすべてのリソースを任意のURLに正しくロードできるようにします。

Vercel Single Page Application(SPA)展開ガイド:ディープURLアセットの負荷の問題の解決 Vercel Single Page Application(SPA)展開ガイド:ディープURLアセットの負荷の問題の解決 Aug 13, 2025 pm 01:03 PM

このチュートリアルは、Vercelにシングルページアプリケーション(SPA)を展開するときにマルチレベルのURL( /プロジェクト /ホームなど)にアクセスするときに、資産(CSS、JS、画像など)をロードする問題を解決することを目的としています。コアは、vercelのルーティング書き換えメカニズムとHTMLの相対/絶対パスの違いを理解することにあります。 vercel.jsonを正しく構成することにより、すべての非ファイル要求がindex.htmlにリダイレクトされ、HTMLの資産参照を絶対パスとして修正することにより、任意の深度URLでSPAの安定した動作を達成します。

JavaScriptパフォーマンスの最適化:基本を超えて JavaScriptパフォーマンスの最適化:基本を超えて Aug 03, 2025 pm 04:17 PM

ObjectshapesbyInitializingPropertiesIngiestlytanceativeTainhiddenclassesinjavascriptengines.2.ReducegarbageCollectionPressureByReusingObjects、避けてください

See all articles