If you are using our free Divi child theme, place this snippet into the scripts.js file and remove the <script> tags at the beginning and end. Otherwise, place this in your Divi>Theme Options>Integrations tab in the “Add code to the < head > of your blog” code area.

<script >

jQuery(function($) {

$(document).ready(function() {

$(“body ul.et_mobile_menu li.menu-item-has-children, body ul.et_mobile_menu  li.page_item_has_children”).append(‘<a href=”#” class=”mobile-toggle”></a>’);

$(‘ul.et_mobile_menu li.menu-item-has-children .mobile-toggle, ul.et_mobile_menu li.page_item_has_children .mobile-toggle’).click(function(event) {






iconFINAL = ‘P’;

$(‘body ul.et_mobile_menu li.menu-item-has-children, body ul.et_mobile_menu li.page_item_has_children’).attr(‘data-icon’, iconFINAL);

$(‘.mobile-toggle’).on(‘mouseover’, function() {


}).on(‘mouseout’, function() {






Add Some CSS To Collapse The Divi Mobile Menu Submenus

The next step is to add the corresponding CSS code. This code works alongside the Jquery and together they create the Divi mobile menu collapsed effect.

If you are using our free Divi child theme, place this snippet into the style.css file. Otherwise, place this in your Divi>Theme Options>Custom CSS code box.

/*change hamburger icon to x when mobile menu is open*/

#et_mobile_nav_menu .mobile_nav.opened .mobile_menu_bar::before,

.et_pb_module.et_pb_menu .et_mobile_nav_menu .mobile_nav.opened .mobile_menu_bar::before {

content: ‘\4d’;


/*adjust the new toggle element which is added via jQuery*/

ul.et_mobile_menu li.menu-item-has-children .mobile-toggle,

ul.et_mobile_menu li.page_item_has_children .mobile-toggle,

.et-db #et-boc .et-l ul.et_mobile_menu li.menu-item-has-children .mobile-toggle,

.et-db #et-boc .et-l ul.et_mobile_menu li.page_item_has_children .mobile-toggle {

width: 44px;

height: 100%;

padding: 0px !important;

max-height: 44px;

border: none;

position: absolute;

right: 0px;

top: 0px;

z-index: 999;

background-color: transparent;


/*some code to keep everyting positioned properly*/



ul.et_mobile_menu>li.menu-item-has-children .sub-menu li.menu-item-has-children,

.et-db #et-boc .et-l ul.et_mobile_menu>li.menu-item-has-children,

.et-db #et-boc .et-l ul.et_mobile_menu>li.page_item_has_children,

.et-db #et-boc .et-l ul.et_mobile_menu>li.menu-item-has-children .sub-menu li.menu-item-has-children {

position: relative;


/*remove default background color from menu items that have children*/

.et_mobile_menu .menu-item-has-children>a,

.et-db #et-boc .et-l .et_mobile_menu .menu-item-has-children>a {

background-color: transparent;


/*hide the submenu by default*/

ul.et_mobile_menu .menu-item-has-children .sub-menu,

#main-header ul.et_mobile_menu .menu-item-has-children .sub-menu,

.et-db #et-boc .et-l ul.et_mobile_menu .menu-item-has-children .sub-menu,

.et-db #main-header ul.et_mobile_menu .menu-item-has-children .sub-menu {

display: none !important;

visibility: hidden !important;


/*show the submenu when toggled open*/

ul.et_mobile_menu .menu-item-has-children .sub-menu.visible,

#main-header ul.et_mobile_menu .menu-item-has-children .sub-menu.visible,

.et-db #et-boc .et-l ul.et_mobile_menu .menu-item-has-children .sub-menu.visible,

.et-db #main-header ul.et_mobile_menu .menu-item-has-children .sub-menu.visible {

display: block !important;

visibility: visible !important;


/*adjust the toggle icon position and transparency*/

ul.et_mobile_menu li.menu-item-has-children .mobile-toggle,

.et-db #et-boc .et-l ul.et_mobile_menu li.menu-item-has-children .mobile-toggle {

text-align: center;

opacity: 1;


/*submenu toggle icon when closed*/

ul.et_mobile_menu li.menu-item-has-children .mobile-toggle::after,

.et-db #et-boc .et-l ul.et_mobile_menu li.menu-item-has-children .mobile-toggle::after {

top: 10px;

position: relative;

font-family: “ETModules”;

content: ‘\33’;

color: #00d263;

background: #f0f3f6;

border-radius: 50%;

padding: 3px;


/*submenu toggle icon when open*/

ul.et_mobile_menu li.menu-item-has-children.dt-open>.mobile-toggle::after,

.et-db #et-boc .et-l ul.et_mobile_menu li.menu-item-has-children.dt-open>.mobile-toggle::after {

content: ‘\32’;


/*add point on top of the menu submenu dropdown*/

.et_pb_menu_0.et_pb_menu .et_mobile_menu:after {

position: absolute;

right: 5%;

margin-left: -20px;

top: -14px;

width: 0;

height: 0;

content: ”;

border-left: 20px solid transparent;

border-right: 20px solid transparent;

border-bottom: 20px solid #ffffff;


/*adjust the position of the hamburger menu*/

.mobile_menu_bar {

position: relative;

display: block;

bottom: 10px;

line-height: 0;


/*force the background color and add a rounded border*/

.et_pb_menu_0.et_pb_menu .et_mobile_menu,

.et_pb_menu_0.et_pb_menu .et_mobile_menu ul {

background-color: #ffffff!important;

border-radius: 10px;



Make The Menu Fullwidth

.container.et_menu_container {
width: calc( 100% – 60px);

.et_mobile_menu {
margin-left: -30px;
padding: 5%;
width: calc( 100% + 60px);