Domanda

Dove posso trovare un elenco di tutti i ganci di WordPress e funzioni sovra-pedalabili (pluggable, script, ecc)?

Modifica Plugin è elencati qui .

È stato utile?

Soluzione

@Arlen: Come Keith S sottolinea Adam Brown Elenco di Ganci è la risorsa de facto di ganci per WordPress. Tuttavia, non è perfetto:

  • non mostra i ganci in ordine di quando sono chiamati,
  • non fornisce il nome del file o il numero di riga dove invocato,
  • non fornisce un certo numero di argomenti passati,
  • Non è una lista completa perché alcuni ganci possono essere chiamati in modo dinamico,
  • E non mostra i ganci dal plugin.

Così, mentre la lista di Adamo è una grande risorsa soprattutto per capire quando sono state storicamente aggiunti ganci non è quasi come utile come se tu fossi in grado di strumento ganci in un dato pagina sul proprio sito.

Sono stato a giocare con questa idea per un po 'così la tua domanda mi ha attivato per scrivere un plug-in denominato " Apparecchio Ganci per WordPress ". È possibile trovare il sorgente completo seguente il colpo dello schermo e si può possibile anche scaricarlo da Gist qui .

Quindi, ecco uno screenshot di quello che gli sguardi strumentazione come:

Schermata dello strumento Ganci per WordPress Plugin in azione

si attiva la strumentazione utilizzando il parametro instrument=hooks URL, cioè:.

http://example.com?instrument=hooks

E come promesso, ecco la sorgente (o scaricarlo qui .):

<?php
/*
Plugin Name: Instrument Hooks for WordPress
Description: Instruments Hooks for a Page. Outputs during the Shutdown Hook.
Version: 0.1
Author: Mike Schinkel
Author URI: http://mikeschinkel.com
*/

if ($_GET['instrument']=='hooks') {

    add_action('shutdown','instrument_hooks');
    function instrument_hooks() {
        global $wpdb;
        $hooks = $wpdb->get_results("SELECT * FROM wp_hook_list ORDER BY first_call");
        $html = array();
        $html[] = '<style>#instrumented-hook-list table,#instrumented-hook-list th,#instrumented-hook-list td {border:1px solid gray;padding:2px 5px;}</style>
<div align="center" id="instrumented-hook-list">
    <table>
        <tr>
        <th>First Call</th>
        <th>Hook Name</th>
        <th>Hook Type</th>
        <th>Arg Count</th>
        <th>Called By</th>
        <th>Line #</th>
        <th>File Name</th>
        </tr>';
        foreach($hooks as $hook) {
            $html[] = "<tr>
            <td>{$hook->first_call}</td>
            <td>{$hook->hook_name}</td>
            <td>{$hook->hook_type}</td>
            <td>{$hook->arg_count}</td>
            <td>{$hook->called_by}</td>
            <td>{$hook->line_num}</td>
            <td>{$hook->file_name}</td>
            </tr>";
        }
        $html[] = '</table></div>';
        echo implode("\n",$html);
    }

    add_action('all','record_hook_usage');
    function record_hook_usage($hook){
        global $wpdb;
        static $in_hook = false;
        static $first_call = 1;
        static $doc_root;
        $callstack = debug_backtrace();
        if (!$in_hook) {
            $in_hook = true;
            if ($first_call==1) {
                $doc_root = $_SERVER['DOCUMENT_ROOT'];
                $results = $wpdb->get_results("SHOW TABLE STATUS LIKE 'wp_hook_list'");
                if (count($results)==1) {
                    $wpdb->query("TRUNCATE TABLE wp_hook_list");
                } else {
                    $wpdb->query("CREATE TABLE wp_hook_list (
                    called_by varchar(96) NOT NULL,
                    hook_name varchar(96) NOT NULL,
                    hook_type varchar(15) NOT NULL,
                    first_call int(11) NOT NULL,
                    arg_count tinyint(4) NOT NULL,
                    file_name varchar(128) NOT NULL,
                    line_num smallint NOT NULL,
                    PRIMARY KEY (first_call,hook_name))"
                    );
                }
            }
            $args = func_get_args();
            $arg_count = count($args)-1;
            $hook_type = str_replace('do_','',
                str_replace('apply_filters','filter',
                    str_replace('_ref_array','[]',
                        $callstack[3]['function'])));
            $file_name = str_replace($doc_root,'',$callstack[3]['file']);
            $line_num = $callstack[3]['line'];
            $called_by = $callstack[4]['function'];
            $wpdb->query("INSERT wp_hook_list
                (first_call,called_by,hook_name,hook_type,arg_count,file_name,line_num)
                VALUES ($first_call,'$called_by()','$hook','$hook_type',$arg_count,'$file_name',$line_num)");
            $first_call++;
            $in_hook = false;
        }
    }
}

Altri suggerimenti

Debug Bar Azione Ganci plug

Visualizza un elenco di azioni licenziato per la richiesta corrente. Richiede la barra di debug di plug-in.

Il Codex ha un Azione di riferimento e un filtro di riferimento . Adam Brown ha creato una gancio di database che ha tutti i ganci nel codice sorgente, e aggiunge la documentazione dalle pagine wiki , le informazioni sulla versione e link al codice sorgente. È possibile migliorarlo scrivendo documentazione nel Codex.

Naturalmente, alcuni ganci sono dinamici, a seconda altri dati. Prendere la funzione wp_transition_post_status :

function wp_transition_post_status($new_status, $old_status, $post) {
    do_action('transition_post_status', $new_status, $old_status, $post);
    do_action("${old_status}_to_$new_status", $post);
    do_action("${new_status}_$post->post_type", $post->ID, $post);
}

Se si registra un tipo di messaggio personalizzato event e cancelled stato di posta personalizzato, si avrà un gancio azione cancelled_event.

Anche se primitiva, forse questo codice plugin può aiutare? Switch "add_action" con "add_filter", se si vuole guardare filtri, invece. Caricare il plug-in e quindi aggiornare la home page del sito. Una volta caricato, è un grave dolore per disattivare, quindi basta rinominare il file plugin sotto i plugin cartella e aggiornare di nuovo il sito - si disattiverà automaticamente. Ho usato questo trucco molte volte una delle cose individuare o trovare un posto dove posso inserire qualcosa.

<?php
/*
Plugin Name: Hooks
Plugin URI: http://example.com/
Description: Hooks
Version: 1.00
Author: Hooks
Author URI: http://example.com/
*/

add_action('all','hook_catchall');
function hook_catchall(&$s1 = '', &$s2 = '', &$s3 = '', &$s4 = '') {
    echo "<h1>1</h1>\n";
    print_r($s1);
    echo "<br />\n";
    echo "<h1>2</h1>\n";
    print_r($s2);
    echo "<br />\n";
    echo "<h1>3</h1>\n";    
    print_r($s3);
    echo "<br />\n";
    echo "<h1>4</h1>\n";    
    print_r($s4);
    echo "<br />\n";
    return $s1;
}

Io uso thiss per trovare l'ordine di ganci. Per ottenere il la filters basta cambiare add_action a add_filter.

function echo_all_hooks() {
$not_arr = array('gettext','sanitize_key','gettext_with_context','attribute_escape');
if(!in_array(current_filter(),$not_arr)) echo current_filter()."<br/>";
}
add_action('all','echo_all_hooks');

Come @kaiser suggeriscono di non pubblicare solo i collegamenti sto migliorando esso. ma non è possibile utilizzare intero codice qui in modo che io sto usando pochi immagine qui a spiegare che come si dispone di un elenco completo per WordPress ganci con descrivere ogni. lo si può trovare qui per ganci , classi , funzioni , plugin , entrare descrizione dell'immagine qui

per descrivere ogni entrare descrizione dell'immagine qui

Si può semplicemente utilizzare un plugin monitor di query: https://wordpress.org/plugins/query -monitor /

entrare descrizione dell'immagine qui

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a wordpress.stackexchange
scroll top