The Easiest Way to Make Your WordPress Divi Accordion Start Out Closed

Many people who use the WordPress Divi accordion want it to start out closed by default. Every WordPress client that I’ve used it for has asked for that, and there are many people online asking about it.

The way it works now is that the first element of the accordion defaults to open, which looks kind of strange.

Existing Solutions

If you look for solutions online, you’ll find a bunch of JavaScript fixes to make the accordion default to closed. That was my first approach as well. But, some of these solutions don’t work anymore (broken in an update), and any JavaScript solution that works today is in danger of going obsolete in a future Divi update.

I’ve found a drop-dead simple solution that does not involve JavaScript (or any other programming) and will never go out of date!

UPDATE: Since I write this article, Elegant Themes has published a JavaScript method to make the accordion default to closed. See the story here and jump to “Close Accordions by Default”. Note, you still might want to use my solution because it uses no JavaScript!

The Solution: Make an Invisible First Row!

The solution I came up with is to make a dummy first row which is invisible!

After you create your regular accordion items, create one with the title of “Invisible” (actually, it can be called whatever you want).

Go to the Custom CSS tab for that item and scroll down to Toggle Title. Enter “display: none;” here as shown below.

Divi Accordion CSS

Save the item.

Next, drag it to the top of the Item list so that it is first as shown below:

Divi Accordion

Save the module and the page.

Voila! The accordion should appear closed when you go to your site!  Check out this example:

Divi Accordion with all items closed!

How it Works

In reality, the first item of the accordion is open. But, it’s invisible, so the real accordion elements that you care about all look closed!

Clicking any visible element will open it as usual.  No one will know there’s an invisible one there!

As a bonus, you get a line on top, which is something that I think makes it look nicer.  If you don’t like it, you can “display:none” the entire first row (not just the text).

Bonus – How to Make a “Close Accordion” Button

The other thing that everyone asks for is the ability to close an accordion element by clicking it again. Right now, the only way to close one is to open another. There’s no way to close all elements in the default accordion.

But, you can use a variation of the technique I described above to create a “close all” button.  Simply create an accordion item with no content, but with the title, “Close All” (or whatever you want the button to be called).

I recommend styling it differently to make it look more like a button.  I added CSS to the Toggle Title area of the Custom CSS section to make the font smaller and lighter than the other accordion titles.

Finally, hide the plus button by adding “display:none;” to the Toggle Icon area of the Custom CSS section of the item.

Voila! This accordion item will behave just like a “close accordion” button.  But, all it is is an accordion item with no content!

There is a paid plugin called Divi Booster that claims to let you close an open accordion item by clicking it again (which is really what we want), but I haven’t tried it yet.

Elegant Themes, please get on this! Until then, hope these hacks are helpful.

Let me know in the comments what you think. – Brian

6 thoughts on “The Easiest Way to Make Your WordPress Divi Accordion Start Out Closed

  1. Thank you!

    This actually lead me to making the following related customizations to use the top row as a Header.

    In the “header” row, set Icon, open and closed backgrounds to the same color. Then added the custom CSS Border: none; to Main Element (thanks, Alyssa below!) and both text-align: center; and font-size: 200%;

    With all that set, your first row will now act as a header and the accordion will appear to start closed!

    Thanks again!

Leave a Comment or Ask a Question