DevExtreme v24.1 is now available.

Explore our newest features/capabilities and share your thoughts with us.

Your search did not match any results.

JavaScript/jQuery Popover

The JavaScript Popover component shows pop-up notifications within a box with an arrow that points to a specified UI element. In this demo, you can hover the mouse pointer over one of the details labels or click the more link to display JavaScript Popover.

DevExtreme Accessibility Compliance
DevExtreme component libraries meet a variety of WCAG and Section 508 compliance standards. To assess this demo’s accessibility level, click the Run AXE® Validation button to launch the AXE® web accessibility evaluation tool.
All trademarks or registered trademarks are property of their respective owners. AXE® Terms of Use
The overall accessibility level of your application depends on the Popover features used.
Backend API
$(() => { $('#popover1').dxPopover({ target: '#link1', showEvent: 'mouseenter', hideEvent: 'mouseleave', position: 'top', width: 300, }); $('#popover2').dxPopover({ target: '#link2', showEvent: 'mouseenter', hideEvent: 'mouseleave', position: 'bottom', width: 300, showTitle: true, title: 'Details:', }); $('#popover3').dxPopover({ target: '#link3', showEvent: 'mouseenter', hideEvent: 'mouseleave', position: 'top', width: 300, animation: { show: { type: 'pop', from: { scale: 0 }, to: { scale: 1 }, }, hide: { type: 'fade', from: 1, to: 0, }, }, }); $('#popover4').dxPopover({ target: '#link4', showEvent: 'dxclick', position: 'top', width: 300, shading: true, shadingColor: 'rgba(0, 0, 0, 0.5)', }); });
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml" lang="en"> <head> <title>DevExtreme Demo</title> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=5.0" /> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script> <script>window.jQuery || document.write(decodeURIComponent('%3Cscript src="js/jquery.min.js"%3E%3C/script%3E'))</script> <link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/24.1.7/css/dx.light.css" /> <script src="js/dx.all.js"></script> <link rel="stylesheet" type="text/css" href="styles.css" /> <script src="index.js"></script> </head> <body class="dx-viewport"> <div class="demo-container"> <div class="dx-fieldset form"> <div class="dx-field"> <div class="dx-field-label">Default mode</div> <div class="dx-field-value-static"> <p><span id="subject1">Google AdWords Strategy</span> (<a id="link1">details</a>)</p> <div id="popover1"> Make final decision on whether we are going to increase our Google AdWord spend based on our 2013 marketing plan. </div> </div> </div> <div class="dx-field"> <div class="dx-field-label">With title</div> <div class="dx-field-value-static"> <p> <span id="subject2"> Rollout of New Website and Marketing Brochures </span> (<a id="link2">details</a>) </p> <div id="popover2"> The designs for new brochures and website have been approved. Launch date is set for Feb 28. </div> </div> </div> <div class="dx-field"> <div class="dx-field-label">With animation</div> <div class="dx-field-value-static"> <p> <span id="subject3"> Create 2012 Sales Report </span> (<a id="link3">details</a>) </p> <div id="popover3"> 2012 Sales Report has to be completed so we can determine if major changes are required to sales strategy. </div> </div> </div> <div class="dx-field"> <div class="dx-field-label">With overlay</div> <div class="dx-field-value-static"> <p> <span id="subject4">Website Re-Design Plan</span> (<a id="link4">more</a>) </p> <div id="popover4"> The changes in our brochure designs for 2013 require us to update key areas of our website. </div> </div> </div> </div> </div> </body> </html>
.form a { cursor: pointer; white-space: nowrap; border-bottom: 1px dashed; text-decoration: none; } .form p { margin: 0; } #link4 { border-bottom-style: solid; }

Attach JavaScript Popover to a Page Element

JavaScript Popover displays an arrow that points to a page element. To specify the element, set the target property to a CSS selector. In this demo, target elements are selected by id.

You can use the position property to position JavaScript Popover relative to the target element. If you do not specify this property, JavaScript Popover is displayed under the element.

Show and Hide JavaScript Popover

The showEvent and hideEvent properties allow you to show and hide JavaScript Popover in response to certain events. These properties can accept one or multiple names of DOM events or DevExtreme UI events separated by a space character.

You can also specify a delay before the events occur. Set the showEvent and hideEvent properties to an object with the name (one or multiple event names) and delay properties.

In this demo, the last JavaScript Popover appears when you click its target element because its showEvent property is set to the DevExtreme dxclick event. Other JavaScript Popover components appear and disappear on the mouseenter and mouseleave DOM events.

Specify Content

JavaScript Popover consists of content area and a title. You can specify static content in the HTML markup as shown in this demo. If JavaScript Popover should display dynamic content, use the contentTemplate property to specify a template. To display the title, enable the showTitle property and set the title property to the title text.

Animate JavaScript Popover

If you want to show and hide JavaScript Popover with animation effects, assign an object with the show and hide fields to the animation property. Each of these fields accepts an object that configures the animation type and other properties. In this demo, JavaScript Popover appears with a pop-up animation and fades away when it disappears.

Shade the Background

You can show JavaScript Popover with a shaded background. To do this, enable the shading property and specify a shadingColor.