概要
woocommerce_register_form_tag
は、WooCommerceのユーザー登録フォームに対してカスタマイズを行うためのアクションフックです。このフックを使用することで、追加のフィールドをフォームに追加したり、既存の設定を変更することが可能になります。一般的に以下のような機能を実装する際に利用されます。
- ユーザー登録フォームのカスタムフィールド追加
- 入力データのバリデーション
- フォームに対する特別なCSS/JavaScriptの追加
- フォーム送信時のデータ処理
- メール通知の追加
- 既存のフィールドの動的な変更
構文
do_action( 'woocommerce_register_form_tag' );
パラメータ
このアクションはパラメータを受け取りません。
戻り値
このアクションは戻り値を返しません。
使用可能なバージョン
- WooCommerceバージョン:3.0.0以降
- WordPressバージョン:4.0以降
サンプルコード
サンプル1: ユーザー登録フォームにカスタムフィールドを追加
add_action( 'woocommerce_register_form_tag', 'add_custom_registration_field' );
function add_custom_registration_field() {
?>
<p class="form-row form-row-wide">
<label for="reg_custom_field"><?php _e( 'Custom Field', 'woocommerce' ); ?></label>
<input type="text" class="input-text" name="custom_field" id="reg_custom_field" value="<?php if ( ! empty( $_POST['custom_field'] ) ) echo esc_attr( wp_unslash( $_POST['custom_field'] ) ); ?>" />
</p>
<?php
}
このサンプルコードは、ユーザー登録フォームに「Custom Field」という名前のカスタムテキストフィールドを追加します。
サンプル2: カスタムフィールドのバリデーション
add_action( 'woocommerce_register_post', 'validate_custom_registration_field', 10, 3 );
function validate_custom_registration_field( $username, $email, $validation_errors ) {
if ( empty( $_POST['custom_field'] ) ) {
$validation_errors->add( 'custom_field_error', __( 'Custom field is required.', 'woocommerce' ) );
}
}
このサンプルコードは、カスタムフィールドが空であればエラーメッセージを表示するバリデーションを追加します。
サンプル3: フォーム送信後のデータ処理
add_action( 'woocommerce_created_customer', 'save_custom_field_registration', 10, 1 );
function save_custom_field_registration( $customer_id ) {
if ( isset( $_POST['custom_field'] ) ) {
update_user_meta( $customer_id, 'custom_field', sanitize_text_field( $_POST['custom_field'] ) );
}
}
このサンプルコードは、登録されたユーザーのカスタムフィールドのデータをユーザーメタとして保存します。
サンプル4: カスタムCSSの追加
add_action( 'wp_enqueue_scripts', 'enqueue_custom_registration_style' );
function enqueue_custom_registration_style() {
if ( is_account_page() ) {
wp_enqueue_style( 'custom-registration-style', get_stylesheet_directory_uri() . '/css/custom-registration.css' );
}
}
このサンプルコードは、アカウントページが表示されるときに、カスタムCSSファイルを読み込みます。これにより、登録フォームのスタイルを変更できます。
サンプル5: 登録後のメール通知
add_action( 'woocommerce_created_customer', 'send_custom_registration_email', 10, 1 );
function send_custom_registration_email( $customer_id ) {
$user = get_userdata( $customer_id );
wp_mail( $user->user_email, __( 'Welcome!', 'woocommerce' ), __( 'Thank you for registering!', 'woocommerce' ) );
}
このサンプルコードは、新しいユーザーが登録されたときに、ウェルカムメールを送信します。
この関数のアクションでの使用可能性
アクション | 使用例 |
---|---|
mu_plugin_loaded | |
registered_post_type | |
plugins_loaded | |
wp_roles_init | |
setup_theme | |
after_setup_theme | |
set_current_user | |
init | |
register_sidebar | |
wp_loaded | |
send_headers | |
parse_query | |
pre_get_posts | |
wp | |
template_redirect | |
get_header | |
wp_head |