Deactivate Plugins Per Page - Improve WordPress Performance

Deactivate Plugins Per Page - Improve WordPress Performance

(17) 5.00 stars
130 Sales

Short Description

With “Deactivate Plugins Per Page” you can easily disable plugins on certain WordPress pages (or on all except a selected page).

This is useful for speeding up your site mainly because many front-end plugins will load their JavaScript and CSS assets on every page, even if you use them on one page.

How it works?

You can add deactivation rules for active plugins. For example for a contact form plugin, that you only use on the contact page, simply add a rule to deactivate it on all URI except on the contact page.

Deactivation Rules Options

1. Deactivation Type
- Deactivate on selected URI
- Deactivate on all URI except selected

2. URI selection type
- Page
- Custom

3. [Page] Select pages to extract URI from (it will update automatically if the page slug changes)

3. [Custom] Custom URI condition
- URI equals …
- URI does not equal …
- URI contains …
- URI does not contain …
- URI starts with …
- URI does not start with …
- URI ends with …
- URI does not end with …

4. Affected devices
- All
- Desktop
- Mobile

Plugin Groups

Create groups of multiple plugins in order to add deactivation rules that affect them all.

Debug Mode

Enable debug mode to see what is the URI and which plugins are active/inactive on the current page on the front-end. This will help you create rules and test current ones. A debug box will appear on the front-end if you are an administrator user.

Does it affect the Back-end?

There is an option (not enabled by default) that makes all rules with Custom URI selection to also affect the back-end. Some back-end pages will still not be affected in order to avoid problems, like the pages that control plugin activation, deactivation, updates, and installation.

Client Reviews


Group plugins that work together

If you have a plugin that requires another plugin to be active in order to work, you need to add these plugins in a plugin group, and add deactivation rules to that group. Deactivating only one of these could lead to errors or the global deactivation of the other plugin.

Don’t deactivate plugins required by your theme

Some themes require certain plugins in order to work properly. If you deactivate these plugins you may experience problems.

Deactivation hooks will not run

When plugins are deactivated via my plugin, the actual deactivation function is not called, and the deactivation hooks will not run. Instead, to make it work per page, plugins are just dynamically removed from the list of active plugins before the page loads. This means that if a plugin has some actions that it performs when it is deactivated, these actions will not run when it is deactivated via my plugin.

For example, some plugins add code to your ”.htaccess” file when they are activated, and when they are deactivated, they remove it. In this case if you add a deactivation rule with my plugin to stop the plugin on a certain page, the ”.htaccess” code will still be there and work on that page, even though the plugin will not be active on it.

Don’t use this plugin to hide sensitive data

It is not made to work securely for that. It is mainly made for site speed optimization and it can also be used for debugging or solving plugin compatibility issues.

Backup your site

Deactivating plugins per page is not a natural thing for WordPress, and plugin and theme developers are not expecting that. It works great in most cases, but sometimes can lead to problems, to other plugins being deactivated or settings being changed. Always have a recent backup of your site and if you can, test your changes in a staging site.

Feedback / Support / Questions

Use the support section (requires sign-in), or my email

Currently Tested Up To

These are the highest versions of WordPress and PHP where I have tested the plugin. They are not required, it will work with lower versions too. It could also work with higher versions, but it is not tested at this time on higher ones.
WordPress 5.6
PHP 7.4.11


1.12.0 – 2 January 2021

ADDED: An option to show plugins that have rules before all other plugins in the Active / Inactive Plugins sections.

ADDED: Links to select all and deselect all pages when adding or editing rule, and the same for plugins when adding or editing a group. Also a counter for the number of currently selected.

ADDED: An option to enable Local Mode. In local mode all deactivations affect only your device, which is detected by a cookie.

IMPROVED: Some buttons now have a text description as well (instead of just an icon), so it is more clear what they do.

IMPROVED: The calculated list of active plugins after applying the deactivations is now cached in a global variable for the rest of the request to improve performance.

FIXED: A conflict with some plugins that change the active_plugins option would cause some plugins to be deactivated globally.

FIXED: When editing a rule, if there were pages that are not currently published but are selected, the background green selection color would not be there.

FIXED: If there was only one other plugin active, in the Active Plugins section it would show a message that there are no other plugins active.

UPDATED: Language files.

1.11.0 – 27 July 2020

ADDED: An option to show the plugin icon image next to its name in the Active Plugins and Inactive Plugins sections.

ADDED: An option to cache the admin menus of plugins deactivated on some back-end pages.

ADDED: In a WordPress Multisite you can import the plugin rules and settings into multiple sites at once.

ADDED: An option to enable the plugin debug mode only on the front-end or only on the back-end.

IMPROVED: New layout for the Settings section.

IMPROVED: Compatibility with plugins that change the back-end dashboard address from wp-admin to something else.

FIXED: The iPad device with a Firefox browser was not detected as a mobile device.

UPDATED: Language files.

1.10.0 – 30 January 2020

ADDED: In debug mode you can now perform quick plugin actions for the current URI: deactivate on the current URI, deactivate on all except the current URI, add a plugin to an existing group.

ADDED: A button in the top right of the debug box that reloads the page.

IMPROVED: A notice about caching plugins is shown when changing the affected devices menu in the add/edit rule box.

FIXED: When importing the rules and settings, an error about invalid import data sent was shown, if one of the plugins has a name starting with an empty space.

FIXED: When WP CLI is used, a warning was generated: Warning: in_array() expects parameter 2 to be array, null given…

UPDATED: Language files.

1.9.0 – 13 November 2019

ADDED: Global actions to export or import all rules, groups, and settings of “Deactivate Plugins Per Page”.

FIXED: The width of some drop-down boxes in WordPress 5.3.

UPDATED: Language files.

1.8.0 – 15 October 2019

ADDED: Five plugin (or group) actions: Front-end Deactivate, Back-end Deactivate, Start Plugin Rules, Pause Plugin Rules, Delete Plugin Rules.

ADDED: A text field to find pages when adding or editing a rule.

IMPROVED: Inactive plugins are now shown in red, when adding or editing groups.

IMPROVED: Removed this plugin from the active plugins section.

IMPROVED: Changed the icon for deleting a group, so it is different from the one for deleting rules.

IMPROVED: Better responsive design for some elements on the admin page.

IMPROVED: If enabled, the debug box is now visible on the back-end regardless of the setting for custom URI selection rules affecting the back-end.

UPDATED: Language and documentation files.

1.7.0 – 7 September 2019

ADDED: An option to ignore URI parameters when applying rules with custom URI selection. Popular tracking parameters like fbclid, fb_source, gclid, utm_medium, utm_source, and others are ignored by default.

ADDED: The sections in the admin page are now collapsible. You can show and hide them. The sections are: active plugins, inactive plugins, plugin groups, settings.

ADDED: An icon that indicates which plugins are already part of at least one plugin group, when creating or editing a group.

FIXED: On the plugin admin page, the back-end notices from other plugins were shown further down on the page (instead of at the top).

FIXED: A few spelling mistakes.

UPDATED: Language files.

1.6.0 – 9 August 2019

ADDED: An option to ignore all URI parameters (aka the query string) in the current page URI, when applying the deactivation rules with Page URI selection. This way when some tracking parameters are added to the URI (like for example ?utm_source=facebook&utm_medium=post) the page will still be recognised correctly by the plugin. Does not affect plain permalink structure. This will be enabled by default.

FIXED: In the 1.5.0 version, if debug mode was enabled and if we could not copy automatically the must-use plugin file to its folder, there was a PHP fatal error.

UPDATED: Language files.

1.5.0 – 5 August 2019

ADDED: An option to also affect the back-end dashboard area by all rules with Custom URI selection.

ADDED: An option to control the trailing slash of Page URIs used inside the deactivation rules.

IMPROVED: Changed some words in the admin area to be more clear.

UPDATED: Language files.

1.4.1 – 9 July 2019

FIXED: When editing a plugin group and some of the plugins are currently not installed, even though they show as selected (green and with a checked checkbox), they are not actually selected.

1.4.0 – 8 July 2019

ADDED: The action to edit a rule.

ADDED: The action to edit a plugin group.

UPDATED: Language and documentation files.

1.3.0 – 25 June 2019

ADDED: The ability to add multiple custom conditions in one rule. This makes it possible for example to deactivate a plugin on all URI except if: the URI contains something, or if it ends with something, or some other condition, etc.

ADDED: Links to filter pages by WPML language and also the ability to select pages from multiple languages in the Add New Rule box (if WPML is active).

ADDED: An option in the Add New Rule box to automatically select all translated pages with WPML of selected pages (if WPML is active).

ADDED: An option to show the Plugin Groups section before the Active Plugins.

IMPROVED: The URI values of pages are now updated when the permalink structure is re-saved, even if there are no actual changes to it. This is helpful when some plugin changes the URIs and says to re-save the permalinks. Then we will also catch the URI change made by that plugin.

IMPROVED: In the rules tables, the URI conditions and URI values are in one column now, with URI values in bold.

FIXED: Extracts incorrect URI of a page translated with WPML.

FIXED: Adding the same rule for the same plugin, but with pages selected in a different order, is no longer possible.

FIXED: A PHP warning about array_key_exists() expects parameter 2 to be array, bool given.

UPDATED: Language and documentation files.

1.2.0 – 4 June 2019

ADDED: A way to quickly find a plugin by typing a part of its name in a text field. The other plugins are filtered out temporarily.

ADDED: Global actions: pause all rules, start all rules, and delete all rules.

ADDED: The ability to create plugin groups. Group two or more plugins in order to add deactivation rules that affect them all.

ADDED: An option to remove all the data of this plugin upon its deletion (not for multisite).

ADDED: A warning in the plugin admin page if the version of the must-use plugin file does not match the version of the normal plugin.

FIXED: One confirmation message and also the URI condition in the rules tables were not translatable.

FIXED: The language files will be loaded even if they are only present in the “languages” folder inside the plugin folder and not present in the “wp-content/languages” folder.

FIXED: A small conflict with the Autoptimize plugin that caused an arrow in the debug box to be visible when it should be hidden.

UPDATED: Language and documentation files.

1.1.0 – 14 May 2019

FIXED: When selecting multiple pages for a rule that deactivates on all except selected, it would deactivate everywhere instead.

UPDATED: Language files.

1.0.0 – 13 May 2019

Initial release


Tell us what you think!

We'd like to ask you a few questions to help improve CodeCanyon.

Sure, take me to the survey