序文プロジェクト内の小さな要件ポイントでは、ボタンをクリックして数十の条件ボックスを検証し、すべての条件ボックスにデータが入力(選択)されているかどうか(少なくとも1つの条件が真であるかどうか)を判断し、対応する操作を実行します。 判定条件ボックスには、ラジオボタン単一選択ボックス、チェックボックス複数選択ボックス、入力ボックス、入力数値カウンタ、選択セレクタ、スイッチスイッチなどが含まれます。 このプロジェクトでは、ElementコンポーネントライブラリV2.15.6を使用しています。 さまざまな条件に対応するデータ型とデフォルト値
コードの実装アイデア 1 ifを使用して直接判断すると、コードは次のようになります(変数はシミュレーション変数です) // 複数条件の判定は次のように始まります if (obj.radio1 || obj.checkbox1.length > 0 || obj.input1 || obj.inputNumber1 > 0 || obj.select1 || obj.select2.length > 0 || obj.switch1 || obj.radio2 || obj.checkbox2.length > 0 || obj.input2 || obj.inputNumber2 > 0 || obj.select3 || obj.select4.length > 0 || obj.switch2 ...) { // 何かをする } それ以外 { // 条件が満たされない場合は、これを表示します。$message({ メッセージ: 「条件を選択してもう一度お試しください」 タイプ: '警告' }) 偽を返す } 実際のプロジェクトシナリオでは、変数名には多くの意味的な文字があります。if をいくつか書くだけでは、長い文字列を書くことになります。そして、いくつか書いたら、それ以上書けなくなります (たくさんのくだらないことを書いているように感じます)。 もっとエレガントな方法で実現できるでしょうか? アイデア2判定する変数を配列に入れて、map を使用してブール型に処理し、includes を使用して配列に指定されたブール値が含まれているかどうかを判定します。 // 次のように複数条件判定が始まります const arr = [ obj.radio1、 obj.checkbox1.長さ、 オブジェクト入力1、 obj.入力番号1、 オブジェクト選択1、 obj.select2.長さ、 obj.switch1、 obj.radio2、 obj.checkbox2.長さ、 obj.input2、 obj.inputNumber2、 オブジェクト選択3、 obj.select4.長さ、 オブジェクトスイッチ2 ... ] 定数 arr1 = arr.map(item => Boolean(item)) (arr1.includes(true))の場合{ // 何かをする } それ以外 { // 条件が満たされない場合は、これを表示します。$message({ メッセージ: 「条件を選択してもう一度お試しください」 タイプ: '警告' }) 偽を返す } そうですね、大量の判定をこの方法で処理するとスムーズになりますね。^-^ 要約するjs での if 判定をスムーズにする方法についての記事はこれで終わりです。js での if 判定に関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 参照ドキュメント
以下もご興味があるかもしれません:
|
序文MySQL では、server-id を使用してデータベース インスタンスを一意に識別し、それを...
序文みなさんこんにちは。CSS ウィザードの alphardex です。この記事では、three.j...
新しい CSS プロパティ contain を紹介する前に、読者はページの再描画と再配置が何であるか...
MySQLリモート接続の問題に関しては、会社で働いているときに誰かのコンピュータに保存されているMy...
私たちは Web 開発者として、プロの DBA ではありませんが、データベースなしではやっていけませ...
1. まず、お使いのマシンに応じて、MySQL 公式サイトから対応するデータベースをダウンロードしま...
目次イベントループmiscroTask (マイクロタスク) UI レンダリング (重要なポイント)次...
目次予備的注釈問題の再現データ削除の原則データの再利用どの操作がデータホールの原因になりますか?表領...
目次1. React.FC<> 2. クラスxxはReact.Componentを拡張し...
ここにmysqlドライバmysql.data.dllがあります知らせ:ここではX86バージョンが多く...
この実験のテスト環境: Windows 10+cmd+MySQL5.6.36+InnoDB 1. ト...
製造手順を分析します。 1. リソースを準備してシーンを構築するオンラインでリソースを探すか、私のリ...
目次1. データベースプログラミングの基本条件2. Java でのデータベースプログラミング: JD...
MySQL のページングステートメントの使用制限Oracle や MS SqlServer と比較す...
1. インストールディレクトリにzipパッケージを解凍します。まず、mysql-8.0.11-win...