If you’ve ever had a WordPress blog post or page in which you found yourself writing more than a little HTML, you’ve experienced the frustration of finding your beautiful markup surrounded in
<p> tags. The problem only gets worse when you start throwing jQuery into the mix. Who on earth gave WordPress permission to throw in
<br/> tags inside a
Up until now, we’ve only had a couple of options:
- First, we could use conditional logic to require an external PHP file. This was bad for several reasons.
- It’s not friendly for the end user. Who wants to have to edit a PHP file?
- The content is not in the WordPress database, which means it isn’t searchable inside the dashboard, and it isn’t backed up with the rest of the site.
- It removes framework functionality. Robust WordPress frameworks have places to add content above and below the main post content area, and an external PHP file destroys this greatly.
- The second option is to use the existing plugins to disable WordPress formatting, but none of these plugins empower the user to toggle this setting on a page-by-page basis. After all, most articles don’t have that much
HTMLin them. Nobody wants to go through 500 old blog posts and manually add
<p>tags to them, do they? We didn’t think so either.
As a web designer that’s used WordPress successfully for several years, I finally decided these shenanigans had to stop once and for good. I built a simple but elegant plugin that lets you disable auto-generated HTML on a page-by-page basis.
I hope you use and enjoy Don’t Muck My Markup as much as I enjoyed building it.
Note: this plugin does not work on all WordPress themes, because some themes don’t handle the filter sequence correctly. This plugin does work for well-programmed themes such as the Twenty Fourteen theme and the Genesis Framework (and child themes).
- Upload this plugin to your plugins directory (wp-content/plugins/).
- Activate this plugin.
- Head over to the Edit Post interface for the specific page for which you want to disable WordPress’ auto-formatting.
- In the right sidebar underneath the “Featured Image” box, toggle the checkbox labeled, “Disable auto-formatting for this page/post.”
- Update the page/post.
- To disable formatting across all pages and posts, head over to Tools -> Don’t Muck My Markup.
- Enjoy your newfound control!
Click disable auto-formatting for this post still allows Visual to be clicked, which generated auto-formatting.
To work in all cases, clicking Visual best also be disabled.
I was pulling my hair out dealing with phantom <p> tags and </br> that would just keep popping up.
The internet was useless until I stumbled upon some old forum post that has this plugin linked. Installed it, turned it on and then all my phantoms were gone. Plugin should be called Ghostbuster.
Please pass this plugin along for the users who don’t use the visual editor and write their own website from scratch. It’s a lifesaver!
Thank you for making WordPress less crappy and more professional. To make a system ‘alter’ professional code makes it a system targeted at amateur site builders… thanks for fixing that!
I was banging my head against a wall trying to get a code block from amazon smiles to display correctly on a page. Finally I found this plugin and installed it. Clicked the checkbox on the page I was working on and voila! the layout worked perfectly finally! Thank you so much!
works very well indeed, smooth and problem free. thank you!
Contributors & Developers
“Don't Muck My Markup” is open source software. The following people have contributed to this plugin.Contributors
Interested in development?
- Minor wording change on the settings page to clarify the user options
- Tested with latest version of WordPress, v4.6.1
- Added the full opening to <?php tags to accommodate old servers.
- Tested with latest version of WordPress, v4.4.2
- Adding a new feature that allows users to disable auto formatting across their entire site with the click of a button.
- Updated function as static in main file.
- Checked for is_post() before getting post ID to determine if a given page load should be un-mucked or not.
- Update the description because parts of it were sounding a little archaic.
- Discovered that autosaving was what messed everything up. When a post autosaves, custom meta boxes get reset unless you provision this. Finally bug free.
- Added white space so that checked=”checked” should no longer be buggy