通过PHP在WordPress中获取jQuery版本

时间:2013-06-28 23:26:57

标签: php jquery wordpress

我不确定这是否可行,但我希望能通过PHP以编程方式检索WordPress的内置jQuery版本号。

我更喜欢使用wp_register_script()包含CDN版本的jQuery,然后我使用WordPress的内置jQuery作为后备。

使用CDN版本的问题是,如果WordPress更新其内置版本的jquery,则CDN版本可能不匹配。所以我希望获取版本号(可能使用wp_default_scripts()),然后将其传递给wp_register_script()

关于我如何做到这一点的任何想法?

2 个答案:

答案 0 :(得分:7)

我借鉴了WP jQuery Plus

function hs_script_enqueuer() {
    if( !is_admin() ) {

        // Enqueue so we can grab the built-in version
        wp_enqueue_script( 'jquery' );

        // Get jquery handle - WP 3.6 or newer changed the jQuery handle (once we're on 3.6+ we can remove this logic)
        $jquery_handle = (version_compare($wp_version, '3.6-alpha1', '>=') ) ? 'jquery-core' : 'jquery';

        // Get the WP built-in version
        $wp_jquery_ver = $GLOBALS['wp_scripts']->registered[$jquery_handle]->ver;

        // Just in case it doesn't work, add a fallback version
        $jquery_ver = ( $wp_jquery_ver == '' ) ? '1.8.3' : $wp_jquery_ver;

        // De-register built-in jquery
        wp_deregister_script('jquery');

        // Register CDN version
        wp_register_script( 'jquery', '//ajax.googleapis.com/ajax/libs/jquery/'. $jquery_ver .'/jquery.min.js' );

        // Enqueue new jquery
        wp_enqueue_script( 'jquery' );
    }
}
add_action( 'wp_enqueue_scripts', 'hs_script_enqueuer' );

// Add jquery fallback if CDN is unavailable
function jquery_fallback() {
    echo '<script>window.jQuery || document.write(\'<script src="' . includes_url( 'js/jquery/jquery.js' ) . '"><\/script>\')</script>' . "\n";
}
add_action( 'wp_head', 'jquery_fallback' );

答案 1 :(得分:0)

if( ! function_exists('register_jquery_script') ){

    function register_jquery_script(){

        /* Get jquery handle - WP 3.6 or newer changed the jQuery handle (once we're on 3.6+ we can remove this logic) */
        $jquery_handle = (version_compare($wp_version, '3.6-alpha1', '>=') ) ? 'jquery-core' : 'jquery';

        /* Get the WP built-in version */
        $wp_jquery_ver = $GLOBALS['wp_scripts']->registered[$jquery_handle]->ver;

        /* Just in case it doesn't work, add a fallback version */
        $jquery_ver = ( $wp_jquery_ver == '' ) ? '1.8.3' : $wp_jquery_ver;

        /* the URL to check CDN accessibility */
        $url = 'http://ajax.googleapis.com/ajax/libs/jquery/' . $jquery_ver . '/jquery.min.js';

        /* test CDN accessibility */
        $test_url = wp_remote_fopen($url); 

        /* deregisters the default WordPress jQuery */
        wp_enqueue_script( 'jquery' );
        wp_deregister_script( 'jquery' ); 

        /* if CDN available - load it */
        if( $test_url !== false ) {
            wp_register_script( 'jquery', '//ajax.googleapis.com/ajax/libs/jquery/'. $jquery_ver .'/jquery.min.js', false , false , true );
        }

        /* if CDN unavailable - load local jquery copy */
        else{
            wp_register_script('jquery', get_template_directory_uri() . '/js/jquery.min.js', __FILE__, false, false, true);
        }

        wp_enqueue_script('jquery');

    }

    add_action('wp_enqueue_scripts','register_jquery_script');

}

您必须确保已将本地jquery加载到 template_directory / js / 中,名称为 jquery.min.js

我在wp_footer()中加载所有脚本默认为页面加载性能。 如果您在wp_header()中加载js脚本,则会在行上将最后的 true 更改为 false

wp_register_script( 'jquery' , $src , false , false , false );

享受它!