Improve wordpress performance mobile devices logged in user
In working with a client on performance issues with their wordpress powered website on iPads they were using to beta test, one strange thing became apparent, there was some correlation to a user being logged into the site and the page being choppy and not smooth when the user was not logged in. ย Keep reading below to learn what we did to improve wordpress performance mobile devices logged in user.
The page in question was a fairly large page with a jquery table being loaded with about 100 rows of data displayed in page. ย Initially my thought was the performance issue was simply due to the size of the page or the lack of performance on the older iPad. ย When the page was loaded on a workstation, the page scrolled fine and performance was as expected. ย However, even on the iPad when I logged the user off who was logged into the site, performance came right back to par with the desktop.
In noticing what was going on, my hunch was that the admin bar which is displayed by default at the top of the browser window when a user logs in might be the culprit. ย So in searching around the wordpress forums I saw the snippet of code to disable the admin bar completely using a filter. ย See the code below:
/**Remove Admin Bar */ add_filter( 'show_admin_bar', '__return_false' );
Simply place the above code in your functions.php to effectively disable the bar from being displayed at the top of your browser. ย In testing after the bar was removed, there was an IMMEDIATE improvement. ย In fact the performance went back to what I was seeing without the user logged in which led me to conclude in this case that the admin bar was to blame.
Final Thoughts
If you have a situation where you are troubleshooting chopping page loading or scrolling behavior for logged in users, give the admin bar filter a shot. ย As we saw in this case, the bar can adversely affect performance when it is displayed at the top of the browser along with the page content especially for mobile devices.