Search code examples
phpwordpressparameter-passing

How to pass additional parameter to wordpress filter?


add_filter('wp_list_pages_excludes', 'gr_wp_list_pages_excludes');

function gr_wp_list_pages_excludes($exclude_array) {    
    $id_array=$array('22');
    $exclude_array=array_merge($id_array, $exclude_array);
    return $exclude_array;
}

I'm a newbie to wordpress. The above code works fine. But I need to pass additional argument, say $mu_cust_arg to the function gr_wp_list_pages_excludes. How can I make use of it via apply_filters, or any other methods? Any help is appreciated.

Thanks in advance.


Solution

  • Because WP doesn't accept closures as callbacks (at least, certainly not for add_filter()) the short answer is "you can't". At least, not in a tidy way.

    There are a couple of options here, depending on what you are doing. The first is the best, but you may not be able to use it:

    Write a wrapper function that calls your function:

    function gr_wp_list_pages_excludes_1 ($exclude_array) {
      $custom_arg = 'whatever';
      gr_wp_list_pages_excludes_1($exclude_array, $custom_arg)
    }
    

    This will only work if you are always passing the same custom argument in a given situation - you would write one of these wrapper functions for each different situation, and pass the name of the wrapper function to add_filter(). Alternatively, if you want it to be truly dynamic, you would need to...

    Use a global variable: (Ref: Variable scope, $GLOBALS)

    function gr_wp_list_pages_excludes($exclude_array) {
        global $gr_wp_list_pages_excludes_custom_arg;
        $id_array=$array('22');
        $exclude_array=array_merge($id_array, $exclude_array);
        return $exclude_array;
    }
    

    Using this approach means that you can pass any data you like into the function by assigning it to $gr_wp_list_pages_excludes_custom_arg in the global scope. This is generally regarded as bad practice and heavily frowned upon, because it makes for messy and unreadable code and leaves the memory space littered with extra variables. Note that I have made the variable name very long and specific to the function to avoid collisions - another problem with using global variables. While this will work, only use it if you absolutely have to.