web-dev-qa-db-fra.com

Chargez des fichiers js/css uniquement sur des pages d'interface utilisateur spécifiques.

Comment puis-je adapter cette solution au travail avec mon plugin? (S'il vous plaît voir le lien).

J'ai mis en file d'attente mon script css et js comme suit:

function my_plugin_init() {
 wp_enqueue_script('my_plugin_script', plugins_url('js/the_filepath.js', __FILE__), array('jquery'));
 wp_enqueue_style( 'my_plugin_css', plugins_url( '/css/the_filepath.css', __FILE__ ) );
}

add_action('init', 'my_plugin_init');

J'ai essayé de mettre cela dans le fichier functions.php du thème, mais cela n'a pas fonctionné:

function remove_my_plugin_extras() {
    remove_action('init', 'my_plugin_init');
}

if( !is_page('My_Page') ) {
    add_action('wp_head', 'remove_my_plugin_extras');
}

Le script et les css sont toujours chargés. Comment puis-je adapter la solution dans ce cas?

6
Laxmidi

Les bons crochets

    // Use both for scripts & styles *)
    wp_enqueue_scripts // (for the frontend)
    login_enqueue_scripts // (for the login screen)
    admin_enqueue_scripts // (for the admin dashboard)

*) Lire cet article @wpdevel .

Lecture complémentaire dans le Codex sur les trois crochets

Sur le hook admin_enqueue_scripts, vous avez également un argument: Le $hook_suffix:

add_action( 'admin_enqueue_scripts', function( $hook )
{
    var_dump( $hook );
} );

Crochets page admin

Lorsque vous enregistrez une page de menu (sous) administrateur , vous pouvez enregistrer le résultat, qui est la page accrochée, dans une variable:

function register_admin_page()
{
    // Register (sub)menu page
    $hook_suffix = add_submenu_page( $your_args_array );
    // Add styles to hook
    add_action( "load-{$hook_suffix}", 'callback_function' );
}
// Use one of those hooks to register the page
add_action( 'admin_menu', 'register_admin_page' );
add_action( 'user_admin_menu', 'register_admin_page' );
add_action( 'network_admin_menu', 'register_admin_page' );

// Register your styles & scripts in here
function callback_function()
{
    // do stuff
}

Admin variables globalement disponibles à vérifier

Le suivant

global $hook_suffix, $typenow, $pagenow, $self, $parent_file, $submenu_file

sont disponibles sur un large éventail de pages d'administration. Utilisez-les pour vérifier si vous êtes sur la page demandée dont vous avez besoin et alors seulement faire des choses.

// Example
if ( 'edit.php' !== $GLOBALS['pagenow'] )
    return;

Encore mieux que de tester contre une variable, qui peut être réinitialisée à la volée (exemple) ...

$GLOBALS['wp'] = array( 'lost', 'my', 'contents', );

... utilise l'objet \WP_Screen sur les pages d'administration:

add_action( 'admin_enqueue_scripts', function( $hook )
{
    /** @var \WP_Screen $screen */
    $screen = get_current_screen();

    var_dump( $screen );
    if ( 'post.php' !== $screen->base )
        return;
} );
14
kaiser
function load_custom_wp_admin_style($hook) {
        // $hook is string value given add_menu_page function.
        if($hook != 'toplevel_page_mypluginname') {
                return;
        }
        wp_enqueue_style( 'custom_wp_admin_css', plugins_url('admin-style.css', __FILE__) );
}
add_action( 'admin_enqueue_scripts', 'load_custom_wp_admin_style' );
2
Super Model