説明
について wpforms_process_validate_richtext
アクションは リッチテキスト フォームが送信されたときのフォーム・フィールド。
パラメータ
- フィールドID
- (int)フィールドID。
- フィールド・サブミット
- (配列)そのフィールドに対して送信された、生の/未サニタイズのフィールド値。
- フォームデータ
- (配列) 処理済みのフォーム設定/データ。
ソース
wpforms/includes/fields/class-base.php
詳細情報
アクションは リッチテキスト フォームフィールドで使用できます。 この関数はすべてのフォームフィールドに使用できます。 do_action( wpforms_process_validate_{$field_type}, $field_id, $field_submit, $form_data )
.
例えば 電子メール フィールドでは do_action( wpforms_process_validate_email, $field_id, $field_submit, $form_data )
.
フィールドの値がサニタイズされるのは、処理の後半、つまり wpforms_process_format_{$field_type}
その
例
このアクションを使えば、リッチテキストをスキャンして、冒涜的な言葉など、フォームからの送信をブロックしたい言葉のリストを探したり、このアクションを使って、フォームの隠しフィールドに値を設定するなど、別のアクションのトリガーとなる特定の言葉を探し、入力項目からフィルタリングすることができます。
この例では、このフィールドに冒涜的な表現があるかどうかを検索します。 もし冒涜的な表現があれば、フォームはエラーを表示して送信しません。
/* * Check the paragraph text field for profanity. * * @link https://wpforms.com/developers/wpforms_process_validate_richtext/ * * @param int $field_id Field ID. * @param array $field_submit Unsanitized field value submitted for the field. * @param array $form_data Form data and settings. */ // Optional, you can limit to specific forms. Below, we restrict output to form #3382. if ( absint( $form_data[ 'id' ] ) !== 3382 ) { return $field_id; } function wpf_dev_profanity_filter_rich_text( $field_id, $field_submit, $form_data ) { //Create your list of profanity words separated by commas $blocked_words = array( 'badword1', 'badword2' ); foreach( $blocked_words as $word ) { if(strpos($field_submit, $word) !== FALSE ) { wpforms()->process->errors[ $form_data[ 'id' ] ][ $field_id ] = esc_html__( 'No profanity allowed.', 'wpforms' ); return; } } } add_action( 'wpforms_process_validate_richtext', 'wpf_dev_profanity_filter_rich_text', 10, 3 );