Я пытался загрузить скрипты и стили для виджета WordPress со следующими условиями ...
- Скрипты ДОЛЖНЫ загружаться в ГОЛОВУ (иначе они ломаются).
- Скрипты должны загружаться ТОЛЬКО, когда виджет действительно отображается (они довольно тяжелые).
Я много занимался поиском, и это, кажется, обычная (нерешенная) проблема ... но я надеюсь, что кто-то здесь успешно реализовал обходной путь.
Это лучшее, что у меня есть ...
Ниже приведен простой виджет, который печатает текст на боковой панели. Он успешно загружает jQuery условно (когда виджет фактически отображается) ... хотя только в нижнем колонтитуле! (Примечание: он также может работать только на WordPress 3.3 , хотя этот хак может обеспечить обратную совместимость).
class BasicWidget extends WP_Widget
{
function __construct() {
parent::__construct(__CLASS__, 'BasicWidget', array(
'classname' => __CLASS__,
'description' => "This is a basic widget template that outputs text to the sidebar"
));
}
function form($instance) {
$instance = wp_parse_args( (array) $instance, array( 'title' => '' ) );
$title = $instance['title'];
?>
<p><label for="<?php echo $this->get_field_id('title'); ?>">Title: <input class="widefat" id="<?php echo $this->get_field_id('title'); ?>" name="<?php echo $this->get_field_name('title'); ?>" type="text" value="<?php echo esc_attr($title); ?>" /></label></p>
<?php
}
function update($new_instance, $old_instance) {
$instance = $old_instance;
$instance['title'] = $new_instance['title'];
return $instance;
}
function widget($args, $instance) {
extract($args, EXTR_SKIP);
echo $before_widget;
$title = empty($instance['title']) ? ' ' : apply_filters('widget_title', $instance['title']);
if (!empty($title))
echo $before_title . $title . $after_title;;
echo "<h1>This is a basic widget!</h1>";
echo $after_widget;
// if we're echoing out content, enqueue jquery.
if (!empty($after_widget)) {
wp_enqueue_script('jquery');
}
}
}
add_action( 'widgets_init', create_function('', 'return register_widget("BasicWidget");') );
Кажется, что как только WordPress начинает обрабатывать виджеты, слишком поздно ставить в очередь (или даже отменять регистрацию чего-либо, помещенного в очередь ранее).
Любые идеи будут высоко ценится!
Отметка.
источник
wp_head
вызывается после того, как сценарии заголовка уже распечатаны, поэтому он будет загружать их только в нижний колонтитул, но вы можете вывести его (вместо постановки в очередь) так же, как при использовании таблицы стилей,echo '<script src="path/to/script.js"></script>';
а также для таблицы стилей, невозможно, чтобы она загружалась виджеты не активныwp_enqueue_scripts
вместоwp_head
своих действий. Это позволит вам поместить javascript в верхний или нижний колонтитул. http://codex.wordpress.org/Function_Reference/wp_enqueue_scriptВ качестве альтернативы вы можете попробовать плагин "Widget Logic" ... он использует условные операторы для загрузки виджета.
Это все наоборот, но результат должен быть таким, как ожидалось.
wp_print_scripts & wp_print_styles могут быть правильными хуками, просто добавьте действия к этим хукам с приоритетом 100, чтобы быть последними в очереди. wp_enqueue_script (), wp_enqueue_style (), wp_deregister_script (), wp_deregister_style () ...
В ваших проблемах с кодом выше может отсутствовать параметр приоритета (не тестировался)? WP кодекс
источник
Вы можете просто использовать wp_enqueue_script или wp_enqueue_style в методе (функции) виджета в вашем пользовательском классе виджетов, и он будет загружать сценарии, только если виджет активен. Подробности и пример смотрите здесь: https://wpshed.com/wordpress/load-scripts-styles-widget-active/
источник
function widget( $args, $instance ) { wp_enqueue_script( 'wpshed-front-end', plugin_dir_url( __FILE__ ) . 'wpshed-front-end.js', array( 'jquery' ), '1.0.0', false ); }
«False» в и означает загрузку скрипта в верхнем или нижнем колонтитуле. Чтобы снова подвести итог, используйте wp_enqueue_script или wp_enqueue_style в методе виджета (функция) . Так делают разработчики из WordPress.com/org.