वर्डप्रेस के हुक / एक्शन रन अनुक्रम कैसे प्राप्त करें?


48

add_actionहुक किस क्रम में निष्पादित होते हैं?

अर्थात

init
wp_head
wp_footer
after_theme_setup 
etc...
???
???
???




संपादित करें:

मैंने अपना समाधान भी पोस्ट किया है।


के संभावित डुप्लिकेट wordpress.stackexchange.com/questions/135857/... के रूप में मेरा 25 फ़र, '14 पर पोस्ट किया गया
बाबू

मैंने एसई नियमों में क्या देखा है, एकमात्र विषय की उम्र अब दोहराव के फैसले के लिए मायने नहीं
रखती है

जवाबों:


82

"डेटा! डेटा! डेटा!" वह अधीर होकर रोया। "मैं मिट्टी के बिना ईंटें नहीं बना सकता।"

द एडवेंचर ऑफ द कॉपर बीचेस

तो चलिए बिना किसी प्लग इन के एक इंस्टॉल से कुछ वास्तविक डेटा को इकट्ठा करते हैं और ट्वेंटीवेट थीम केवल एक टेक्स्ट विजेट के साथ सक्रिय होता है।

मुख पृष्ठ के लिए निम्नलिखित do_actionकॉल निम्न क्रम में किए गए हैं:

muplugins_loaded
registered_taxonomy
registered_taxonomy
registered_taxonomy
registered_taxonomy
registered_taxonomy
registered_post_type
registered_post_type
registered_post_type
registered_post_type
registered_post_type
plugins_loaded
sanitize_comment_cookies
setup_theme
unload_textdomain
load_textdomain
after_setup_theme
load_textdomain
load_textdomain
auth_cookie_malformed
auth_cookie_valid
set_current_user
init
registered_post_type
registered_post_type
registered_post_type
registered_post_type
registered_post_type
registered_taxonomy
registered_taxonomy
registered_taxonomy
registered_taxonomy
registered_taxonomy
widgets_init
register_sidebar
register_sidebar
register_sidebar
wp_register_sidebar_widget
wp_register_sidebar_widget
wp_register_sidebar_widget
wp_register_sidebar_widget
wp_register_sidebar_widget
wp_register_sidebar_widget
wp_register_sidebar_widget
wp_register_sidebar_widget
wp_register_sidebar_widget
wp_register_sidebar_widget
wp_register_sidebar_widget
wp_register_sidebar_widget
wp_loaded
parse_tax_query
parse_tax_query
posts_selection
template_redirect
admin_bar_init
add_admin_bar_menus
get_header
wp_head
wp_enqueue_scripts
wp_print_styles
wp_print_scripts
get_template_part_content
begin_fetch_post_thumbnail_html
end_fetch_post_thumbnail_html
get_template_part_content
get_template_part_content
get_template_part_content
get_template_part_content
get_template_part_content
get_template_part_content
get_template_part_content
get_template_part_content
get_template_part_content
begin_fetch_post_thumbnail_html
end_fetch_post_thumbnail_html
get_sidebar
dynamic_sidebar_before
dynamic_sidebar
dynamic_sidebar_after
get_footer
twentytwelve_credits
wp_footer
wp_print_footer_scripts
wp_before_admin_bar_render
wp_after_admin_bar_render
shutdown

यदि आप क्रियाओं के क्रम की जांच करना चाहते हैं और कितनी बार प्रत्येक को निकाल दिया जाता है, तो आप उदाहरण के लिए उपयोग कर सकते हैं:

add_action( 'shutdown', function(){
    print_r( $GLOBALS['wp_actions'] ); 
});

या यह पूर्वनिर्धारित संस्करण:

add_action( 'shutdown', function(){
    foreach( $GLOBALS['wp_actions'] as $action => $count )
        printf( '%s (%d) <br/>' . PHP_EOL, $action, $count );

});

निम्नलिखित सूची प्राप्त करने के लिए:

muplugins_loaded (1) 
registered_taxonomy (10) 
registered_post_type (10) 
plugins_loaded (1) 
sanitize_comment_cookies (1) 
setup_theme (1) 
unload_textdomain (1) 
load_textdomain (3) 
after_setup_theme (1) 
auth_cookie_malformed (1) 
auth_cookie_valid (1) 
set_current_user (1) 
init (1) 
widgets_init (1) 
register_sidebar (3) 
wp_register_sidebar_widget (12) 
wp_loaded (1) 
parse_request (1) 
send_headers (1) 
parse_tax_query (2) 
parse_query (1) 
pre_get_posts (1) 
posts_selection (1) 
wp (1) 
template_redirect (1) 
wp_default_scripts (1) 
wp_default_styles (1) 
admin_bar_init (1) 
add_admin_bar_menus (1) 
get_header (1) 
wp_head (1) 
wp_enqueue_scripts (1) 
wp_print_styles (1) 
wp_print_scripts (1) 
loop_start (1) 
the_post (10) 
get_template_part_content (10) 
begin_fetch_post_thumbnail_html (2) 
end_fetch_post_thumbnail_html (2) 
loop_end (1) 
get_sidebar (1) 
dynamic_sidebar_before (1) 
dynamic_sidebar (1) 
dynamic_sidebar_after (1) 
get_footer (1) 
twentytwelve_credits (1) 
wp_footer (1) 
wp_print_footer_scripts (1) 
admin_bar_menu (1) 
wp_before_admin_bar_render (1) 
wp_after_admin_bar_render (1) 
shutdown (1) 

पुनश्च: आपको जॉन ब्लैकबर्न द्वारा महान क्वेरी मॉनिटर प्लगइन की भी जांच करनी चाहिए । (मैं इस प्लगइन से संबंधित नहीं हूं)


वाकई बहूत बढिया!
jdm2112

क्वेरी मॉनिटर का उल्लेख करने के लिए धन्यवाद। इस मामले पर एक उपयोगी प्लगइन होने लगता है।
DAH

अपडेट के लिए @kraftner धन्यवाद, मैंने हमेशा योजना बनाई (लेकिन इसके बारे में भूल गया) सीधे कहानी को एक उचित स्रोत के रूप में लिंक करने के लिए, जाहिर है कि उस समय मेरा शर्लक होम्स खोज फू महान नहीं था ;-)
birgire

1
मुझे उद्धरण पसंद आया और मैं अधिक संदर्भ देखना चाहता था। और जैसा कि मेरे पास पहले से ही अपने लिए लिंक था क्यों न यहां भी अपडेट किया जाए। :)
क्राफ्टर

1
4 यो पोस्ट और अभी भी उपयोगी। आपका बहुत बहुत धन्यवाद!
सेबेस्टियन काकज़मारेक

20

यहाँ वर्डप्रेस लोड चार्ट है

वर्डप्रेस लोड चार्ट

स्रोत @Rarst द्वारा


9
कम से कम स्रोत जोड़ें , या इससे भी बेहतर: इस प्रश्न के लिए एक डुप्लिकेट ढूंढें।
FUXIA

2
वास्तव में मुझे नहीं पता था कि मुझे यह कहां से मिला है। मेरे पास यह छवि मेरे पीसी पर सहेजी गई थी। नहीं तो मैंने ऐसा किया होता।
राबर्ट ह्यू ने

यह टॉम मैक फरलिन मुखपृष्ठ पर भी प्रकाशित किया गया है: वर्डप्रेस पेज लाइफसाइकल -> tommcfarlin.com/wordpress-page-lifecycle
DAH

3

समाधान मिला!

अच्छा जवाब के लिए धन्यवाद @birgire । मैं इसमें जोड़ दूंगा, muplugins_loadedकभी-कभी निकाल नहीं दिया जाता है, इसलिए मैं plugins_loadedसबसे पहले हुक के रूप में उपयोग करूंगा (लेकिन उस समय, उपयोगकर्ता-प्राधिकरण अभी तक नहीं किया गया है। यदि आप उपयोगकर्ता के प्राधिकरण की जांच करना चाहते हैं, तो उसके initलिए जल्द से जल्द है)। ..

पी एस वहाँ उत्कृष्ट प्लगइन्स मौजूद हैं:

1) क्वेरी मॉनिटर - आप पृष्ठ-लोड, यानी प्रत्येक निष्पादित फ़ंक्शन की अवधि और बहुत कुछ (प्लगइन पृष्ठ पर सभी स्क्रीनशॉट देखें) पर सब कुछ देख सकते हैं:

यहाँ छवि विवरण दर्ज करें

2) WP-DEBUG-BAR + WP-DEBUG-SLOW-ACTIONS :
ए) डीबग हुक ( क्रियाएं ) आपकी साइट पर सूची चलाती हैं।
बी) प्रत्येक क्रिया की अवधि देखें (कार्य नहीं): यहाँ छवि विवरण दर्ज करें


1

कोई भी दो अनुरोध बिलकुल एक जैसे नहीं हैं। एक त्वरित और गंदे (लेकिन बहुत सटीक) तरीके से यह पता लगाने के लिए कि क्या चल रहा है अस्थायी रूप से do_actionफ़ंक्शन के प्रारंभ में एक पंक्ति जोड़ने के लिए wp-includes/plugin.phpजिसमें लॉग लॉग होता है $tag, जैसे:

if (isset($some_get_or_post_trigger_var)) file_put_contents(ABSPATH . 'action.log', "$tag\n", FILE_APPEND);

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.