Wordpress Ajax技术

时间:2012-03-30 17:27:20

标签: php jquery ajax wordpress

我最近一直在玩WordPress实现AJAX。我知道有很多插件可用,但我想自己制作。

在有关AJAXified WordPress的文章中,大多数人建议使用 admin-ajax.php 来处理AJAX请求。我的第一个想法是如何制作它只是创建自定义get_header()和get_footer()

第一路

// Boolean function ?ajax=true
function is_ajax () {
  if($_REQUEST['ajax']) {
    return true;
  } else {
    return false;
  }
}

function ajax_get_header () {
  if(is_ajax()) {
    get_header('ajax'); 
    /* Insert header-ajax.php which
    includes only google analytics tracking code and some minor stuff */
    return true;
  } else {
    get_header();  
    // Standard header
    return true;
  }
}

/* Function ajax_get_footer() pretty much the same */

然后,页面模板看起来像

<?php ajax_get_header(); ?>

<!-- Content -->

<?php ajax_get_footer(); ?>

当然,制作ajax是标准方式。 这种方法让我觉得简单干净。 另一方面,许多人建议使用内置函数,通过创建一个钩子来捕获AJAX调用。

第二路

function process_ajax(){
  /* Show the page or whatever */
}
add_action('wp_ajax_nopriv_ajax', 'process_ajax');
add_action('wp_ajax_ajax', 'process_ajax');

将AJAX调用指向admin-ajax.php

使用哪一个?

我已经尝试了这两种方法并发现第一种方式加载速度明显快于后者。在相同条件下,第一种方式(ajax_get_header)花费大约400ms来加载页面(几乎没有内容),第二种方式(admin-ajax.php)大约需要800ms。我不知道为什么,两种方式加载WP核心并做几乎相同的事情。

所以,我问你,是否有一个严肃的理由通过admin-ajax.php进行AJAX调用?它是必须的吗?为什么通过推荐的方式处理呼叫需要更多时间?

1 个答案:

答案 0 :(得分:1)

你的第一种方式总是比Wordpress自己的ajax更快,因为admin-ajax.php负责很多其他的事情,比如核心管理员钩子和其他功能调用,这反过来又会影响整个ajax调用非常庞大。

在第一种方式中,除了你自己的功能和输出之外,你不会感到烦恼。这提高了性能。

没有硬性规则可以使用,第一种方法可以更快地完成任务但是它们无法与wordpress的核心管理功能联系起来,这可能是某种目的的劣势。

请参阅admin-ajax.php

$core_actions_get = array(
'fetch-list', 'ajax-tag-search', 'wp-compression-test', 'imgedit-preview', 'oembed-cache',
'autocomplete-user', 'dashboard-widgets', 'logged-in',
);

$core_actions_post = array(
'oembed-cache', 'image-editor', 'delete-comment', 'delete-tag', 'delete-link',
'delete-meta', 'delete-post', 'trash-post', 'untrash-post', 'delete-page', 'dim-comment',
'add-link-category', 'add-tag', 'get-tagcloud', 'get-comments', 'replyto-comment',
'edit-comment', 'add-menu-item', 'add-meta', 'add-user', 'autosave', 'closed-postboxes',
'hidden-columns', 'update-welcome-panel', 'menu-get-metabox', 'wp-link-ajax',
'menu-locations-save', 'menu-quick-search', 'meta-box-order', 'get-permalink',
'sample-permalink', 'inline-save', 'inline-save-tax', 'find_posts', 'widgets-order',
'save-widget', 'set-post-thumbnail', 'date_format', 'time_format', 'wp-fullscreen-save-post',
'wp-remove-post-lock', 'dismiss-wp-pointer', 'upload-attachment',
);