WordPress как на ладони
Наставник Трепачёв Д.П., phphtml.net wordpress jino

switch_theme хук-событие . WP 1.5.2

Срабатывает при смене темы. Используется при деактивации темы.

Срабатывает после того как тема была переключена, но до следующего запроса - редиректа. При активации темы происходит редирект на туже самую страницу.

Во время этого события, доступны только функции старой темы, с которой переключаемся. Если нужны функции новой темы, используйте событие after_switch_theme.

Этот хук следует использовать, когда нужно что-то сделать при деактивации темы.

Особенности работы переключения и как это работает шаг за шагом, смотрите в описании after_switch_theme.

Использование

add_action( 'switch_theme', '____action_function_name', 10, 3 );
function ____action_function_name( $new_name, $new_theme, $old_theme ) {
	// Действие...
}
$new_name(строка)
Название новой темы.
$new_theme(WP_Theme)
Объект WP_Theme новой темы. См. wp_get_theme()
$old_theme(WP_Theme)
Объект WP_Theme старой темы.

Примеры

#1 Удаление опций темы при её деактивации

add_action('switch_theme', 'mytheme_del_options');
function mytheme_del_options( $old_name ) {
	delete_option('mytheme_options');
}

#2 Удаление опций при деактивации темы и добавление при активации

// удаляем настройки темы при деактивации
add_action('switch_theme', 'deactivate_my_theme');
function deactivate_my_theme( $old_name ){
	// доступны функции старой темы, но не новой

	delete_option('mytheme_options');
}

// добавляем настройки темы при активации
add_action('after_switch_theme', 'activate_my_theme' );
function activate_my_theme( $new_name ){
	// доступны функции новой темы, но не старой

	$opt = array('opt1'=>'val1', 'opt2'=>'val2');

	add_option('mytheme_options', $opt );
}

Связи хука

Используется в: switch_theme()

Фрагменты кода хука switch_theme

Фрагмент из: wp-includes/theme.php WP 4.8.1
...
		}
	}

	update_option( 'theme_switched', $old_theme->get_stylesheet() );

	/**
	 * Fires after the theme is switched.
	 *
	 * @since 1.5.0
	 * @since 4.5.0 Introduced the `$old_theme` parameter.
	 *
	 * @param string   $new_name  Name of the new theme.
	 * @param WP_Theme $new_theme WP_Theme instance of the new theme.
	 * @param WP_Theme $old_theme WP_Theme instance of the old theme.
	 */
	do_action( 'switch_theme', $new_name, $new_theme, $old_theme );
}

/**
 * Checks that current theme files 'index.php' and 'style.css' exists.
 *
 * Does not initially check the default theme, which is the fallback and should always exist.
 * But if it doesn't exist, it'll fall back to the latest core default theme that does exist.
 * Will switch theme to the fallback theme if current theme does not validate.
 *
 * You can use the {@see 'validate_current_theme'} filter to return false to
 * disable this functionality.
 *
 * @since 1.5.0
 * @see WP_DEFAULT_THEME
 *
...
switch_theme Комментариев нет

Здравствуйте, !

Ваш комментарий