I’m pretty much a total noob to JavaScript and jQuery and I’m having trouble getting a basic dialog box working. Here is my code:
<script type="text/javascript">
$(document).ready(function() {
var dialog = $("#dialog");
dialog.dialog({
title: "Dialog",
modal: true,
draggable: false,
resizable: false,
autoOpen: false,
width: 500,
height: 400
});
dialog.hide();
});
function showDialog() {
$("#dialog").dialog("open");
}
$("ui-widget-overlay").click(function() {
$(".ui-dialog-titlebar-close").trigger("click");
});
</script>
<div id="dialog">
Dialog text.
</div>
<button onclick="showDialog()">Show Dialog</button>
When I click the button, the title bar of the dialog comes up and the background of the page dims, but there are two problems:
- The body of the dialog does not show (all that shows is the title bar)
- When I click outside of the dialog, the dialog does not close. I have to click the “x” in the corner in order for the dialog to close.
I’ve been reading tons of related questions on here, but nothing I try seems to work. Any advice?
I believe the problem you’re having is from this line:
What I would suggest is removing all of the dialog content from the dialog div and populating it when you actually show the dialog.
As for handling the close part, have you tried nesting everything in the main page in a
<div>of its own and then handling that click event?