JavaScriptのforEach内で「continue」や「break」のような動作をさせる方法

配列でループ処理をしたいとき、forEachを使うとかなりラクに実装できます。
ただし、forEach内ではcontinueやbreakが使えません。
今回はその代替となる方法をまとめておきます。
forEachについて
forEachを使うと、配列に含まれる要素を順に取り出してコールバック関数に渡して処理ができます。
let days = ['日', '月' ,'火', '水', '木', '金', '土'];
days.forEach((day, index) =>{
console.log(day);
});これで配列がループされて、コンソールに各配列の値が表示されます。
日
月
火
水
木
金
土continueと同じ動きにする
forEach内でreturnすると、その時点で次のループへスキップされます。
let days = ['日', '月' ,'火', '水', '木', '金', '土'];
days.forEach((day, index) =>{
if(index === 1){
return; // 「月」のみスキップされる
}
console.log(day);
});これで「月」のみスキップされます。
日
火
水
木
金
土ちなみに、returnでもreturn trueでもreturn falseでも関係なくすべて同じ結果になります。
breakと同じ動きにする
breakと同じ動きはforEachではできないため、someを利用します。
使い方はforEachとほとんど変わりませんが、trueを返すとその時点で処理が終了する特性を持っています。
let days = ['日', '月' ,'火', '水', '木', '金', '土'];
days.forEach((day, index) =>{
if(index === 1){
return true; // 「月」の時点で終了する
}
console.log(day);
});これで「月」の時点で終了するので、「日」のみがコンソールに出力されます。
日ただ、someは本来テスト関数として定義されていて本来の使い方とは違いますし、名前からしてループ処理だと判断しにくいのでオススメはしません。
そこまでするくらいだったら素直にforにしてbreakを使った方がよさそうです。

既存プロジェクトにCompassが導入されている場合に備えて、最低限Sassのコンパイルだけでも行えるようにしておく
gitignoreで特定ファイルをGitで無視する方法
Movable Typeでコメントアウトして出力時に無視する方法
EJSのincludeで別ファイルを読み込むときの画像パスを指定する方法
Dart Sassの変数の基本的な使い方|Dart Sass入門
コーディング時に「アノテーションコメント」を使ってコードを見やすく管理する
様々な作業を自動化するgulpの基礎と導入方法
WordPressで「予約投稿の失敗」となってしまう場合の対処方法
コーディング時にちゃんと意識したい複数語の連結方法一覧(キャメルケース・スネークケース・ケバブケース)
Vue CLI 3でfaviconの設定をする方法
iTerm2で「Use System Window Restoration Setting」を設定しているとアラートが表示されて機能しない
Google Chromeのサイト内検索(カスタム検索)機能を別のプロファイルに移行する方法
iPadで入力モードを切り替えずに数字や記号をすばやく入力する方法
iPhoneやiPadでYouTubeの再生速度を3倍速や4倍速にする方法
Keynoteで有効にしているはずのフォントが表示されない現象
MacのKeynoteにハイライトされた状態でコードを貼り付ける方法
AirPodsで片耳を外しても再生が止まらないようにする方法
iTerm2でマウスやトラックパッドの操作を設定できる環境設定の「Pointer」タブ
DeepLで「インターネット接続に問題があります」と表示されて翻訳できないときに確認すること
Ulyssesの「第2のエディタ」表示を使って2つのシートを横並びに表示する
Obsidianで整理した知識をAnkiで定着させる方法
Figma × Keyboard Maestroでどこまで効率化できる?
マウス操作の完成度が高いウインドウリサイズアプリ「Magnet」
Macで複数ディスプレイを使っている場合に便利な設定集
AppCleanerでMacアプリを関連ファイルごと完全に削除する
操作に没頭できる!Firefox版 Arcのようなブラウザ「Zen Browser」
chezmoi(シェモア)で始めるdotfiles管理
GitHubの通知を見逃さない!通知に特化したアプリ「Gitify」
Keyboard Maestroの変数基礎
Neovimを使い始める最初の一歩として便利な「LazyVim」