# Collapse > Easily toggle visibility of almost any content on your pages in a vertically collapsing container. > Includes support for making accordions. Visibility can be easily toggled with our > [`v-b-toggle` directive](/docs/directives/toggle), or via `v-model`. ```html
Toggle Collapse

Collapse contents Here

Toggle Inner Collapse Hello!
``` ## Usage Other elements can easily toggle `` components using the [`v-b-toggle` directive](/docs/directives/toggle). ```html
Toggle Collapse Toggle Collapse I am collapsible content!
``` See the [`v-b-toggle` directive documentation](/docs/directives/toggle) for detailed usage information. ## Initial visibility (start expanded) To make the `` show initially, set the `visible` prop: ```html
Toggle Collapse I should start open!
``` By default, an initially visible collapse will not animate on mount. To enable the collapse expanding animation on mount (when `visible` or `v-model` is `true`), set the `appear` prop on ``. ## `v-model` support The component's collapsed (visible) state can also be set with `v-model` which binds internally to the `visible` prop. Note, when using `v-model` to control ``, the `aria-*` attributes and class `collapsed` are not automatically placed on the trigger button (as is the case when using the `v-b-toggle` directive). In this example we **must control the attributes ourselves** for proper accessibility support. ```html ``` ## Trigger multiple collapse elements You can even collapse multiple `` components via a single `v-b-toggle` by providing multiple target IDs using _modifiers_. You can also pass multiple target IDs via the directive _value_ in BootstrapVue release v2.14.0+. ```html
Toggle Collapse A and B Toggle Collapse A and B Toggle Collapse A and B I am collapsible content A! I am collapsible content B!
``` ## Accordion support Turn a group of `` components into an accordion by supplying an accordion group identifier via the `accordion` prop. Note that only one collapse in an accordion group can be open at a time. ```html ``` **Notes:** - When using accordion mode, make sure you place the trigger elements and `` components inside an element with `role="tablist"` and set `role="tab"` on each trigger element's container (each trigger element should be wrapped) in order to help screen reader users navigate the accordion group. - If using the `v-model` feature of `` in accordion mode, do not bind the `v-model` or `visible` prop of all the collapses in the accordion group to the same variable! - Ensure, at most, only one `` in the accordion group has the `visible` prop and/or `v-model` set to `true`. Only one collapse in an accordion group can be open at a time. ## Hiding and showing content in the toggle button based on collapse state When using the `v-b-toggle` directive, the class `collapsed` will automatically be placed on the trigger element when the collapse is closed, and removed when open. You can use this class to display or hide content within the toggle via custom CSS. As of BootstrapVue 2.14.0, the class `not-collapsed` will be applied when the target(s) are not closed. **Example HTML markup:** ```html
CloseOpen My Collapse
``` **Example Custom CSS:** ```css .collapsed > .when-open, .not-collapsed > .when-closed { display: none; } ``` ## 'Global' \$root instance events Using `$root` instance it is possible to emit and listen events somewhere out of a component, where `` is used. In short, `$root` behaves like a global event emitters and listener. Details about `$root` instance can be found in [the official Vue docs](https://vuejs.org/v2/guide/components-edge-cases.html#Accessing-the-Root-Instance). ### Listening to collapses state changes via \$root events To listen to any collapse state changes, use: ```js export default { mounted() { this.$root.$on('bv::collapse::state', (collapseId, isJustShown) => { console.log('collapseId:', collapseId) console.log('isJustShown:', isJustShown) }) } } ``` where `collapseId` is collapse id which changed its state; `isJustShown` is true/false, i.e. shown/hidden collapse. ### Toggling collapses via \$root events To toggle (open/close) a **specific collapse**, pass the collapse `id`: ```js this.$root.$emit('bv::toggle::collapse', 'my-collapse-id') ``` ## Optionally scoped default slot New in v2.2.0 The default slot can be optionally scoped. The following scope properties are available: | Property | Type | Description | | --------- | -------- | ------------------------------------ | | `visible` | Boolean | Visible state of the collapse | | `close` | Function | When called, will close the collapse | ## Accessibility The `v-b-toggle` directive will automatically add the ARIA attributes `aria-controls` and `aria-expanded` to the component that the directive appears on (as well as add the class `collapsed` when not expanded). `aria-expanded` will reflect the state of the target `` component, while `aria-controls` will be set to the ID(s) of the target `` component(s). If using `v-model` to set the visible state instead of the directive `v-b-toggle`, you will be required to, on the toggle element, add the `aria-controls` and other appropriate attributes and classes yourself. While the `v-b-toggle` directive can be placed on almost any HTML element or Vue component, it is recommended to use a button or link (or similar component) to act as your toggler. Otherwise your trigger elements may be inaccessible to keyboard or screen reader users. If you do place them on something other than a button or link (or similar component), you should add the attributes `tabindex="0"` and `role="button"` to allow users of assistive technology to reach your trigger element. When using accordion mode, make sure you place the trigger elements and `` components inside an element with `role="tablist"` and set `role="tab"` on each trigger element's container in order to help screen reader users navigate the accordion group. Unfortunately, BootstrapVue cannot apply those roles for you automatically, as it depends on your final document markup. **Note:** The animation effect of this component is dependent on the `prefers-reduced-motion` media query. See the [reduced motion section of our accessibility documentation](/docs/reference/accessibility) for additional details. ## See also - [`v-b-toggle` directive](/docs/directives/toggle)