In a WordPress theme, how do you conditionally include scripts for ie8 and below? This is primarily to apply polyfills for various html5/css3 features. I see that wp has the $is_IE variable which can be used as a conditional to only include scripts for IE. Is there a way to add the script for only certain versions of IE though rather than all of them? This is simple with some HTML ie conditional comments, but I'd like to include the scripts all in the same place in my functions file.
Conditional for specific versions in HTML:
<!--[if lt IE 9]> <script src="iepolyfill.min.js"></script> <![endif]-->
Conditional for all IE in WP:
global $is_IE; if ( $is_IE ) { wp_enqueue_script( 'iepolyfill', bloginfo('stylesheet_directory').'/js/iepolyfill.min.js' ); }
I've looked around and mainly find details about conditional scripts for wp backend only.
Any suggestions?
To enqueue scripts and styles in the front-end you'll need to use the wp_enqueue_scripts hook. Within the hooked function you can use the wp_register_script() , wp_enqueue_script() , wp_register_style() and wp_enqueue_style() functions.
Enqueue function in WordPress is used to add styles and scripts on the WordPress website. The wp_enqueue function provides a systematic way of loading the styles and scripts. For a WordPress developer, loading a script or styles really matters.
To add the script in the footer or bottom of a WordPress page, all you need to do is set the $in_footer parameter to true . We have also used another function get_template_directory_uri() which returns the URL for the template directory.
For WordPress 4.2+
Use wp_script_add_data
to wrap the script in a conditional comment:
wp_enqueue_script( 'html5shiv', '//cdn.jsdelivr.net/html5shiv/3.7.2/html5shiv.js' ); wp_script_add_data( 'html5shiv', 'conditional', 'lt IE 9' ); wp_enqueue_script( 'respond', get_template_directory_uri() . '/js/respond.min.js' ); wp_script_add_data( 'respond', 'conditional', 'lt IE 9' );
Just make sure you register the script before invoking wp_script_add_data
(registering is handled by wp_enqueue_script
above), and that the first argument you pass to wp_script_add_data
matches the first argument you passed when you registered the script.
For WordPress 4.1
You can use the script_loader_tag
filter today to enqueue scripts wrapped in conditional comments. Here’s an example implementation:
wp_enqueue_script( 'html5shiv', '//cdn.jsdelivr.net/html5shiv/3.7.2/html5shiv.js', array(), '3.7.2', false ); add_filter( 'script_loader_tag', function( $tag, $handle ) { if ( $handle === 'html5shiv' ) { $tag = "<!--[if lt IE 9]>$tag<![endif]-->"; } return $tag; }, 10, 2 );
And if you want to include more than one script in the same way, you can use something like:
// Conditional polyfills $conditional_scripts = array( 'html5shiv' => '//cdn.jsdelivr.net/html5shiv/3.7.2/html5shiv.js', 'html5shiv-printshiv' => '//cdn.jsdelivr.net/html5shiv/3.7.2/html5shiv-printshiv.js', 'respond' => '//cdn.jsdelivr.net/respond/1.4.2/respond.min.js' ); foreach ( $conditional_scripts as $handle => $src ) { wp_enqueue_script( $handle, $src, array(), '', false ); } add_filter( 'script_loader_tag', function( $tag, $handle ) use ( $conditional_scripts ) { if ( array_key_exists( $handle, $conditional_scripts ) ) { $tag = "<!--[if lt IE 9]>$tag<![endif]-->"; } return $tag; }, 10, 2 );
wp_register_script()
whenever you add scripts to your WP themes or plugins.For IE, conditional tags work very well. Here's how you can add conditional tags into a script, example is for HTML5shiv:
global $wp_scripts; wp_register_script( 'html5shiv', get_bloginfo('template_url').'/assets/js/html5shiv.js', array(), '3.6.2' ); $wp_scripts->add_data( 'html5shiv', 'conditional', 'lt IE 9' );
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With