4

我使用 960 网格系统有以下页面布局

----------------
      header
-----------------
     |           
     |           
 side|    main  
     |
     |
-----------------

当用户单击侧面菜单中的链接时,我想使用 jQuery 对话框显示一个弹出窗口。但是,无论我尝试过什么,对话框的标题栏总是展开以填满全屏。我尝试设置对话框的高度、maxHeight 和 zIndex,但这没有用。我想要的只是让对话框显示在屏幕的中心,只要我不包含 960 css 但我就会失去我的布局。

有什么我想念的吗?

我用于对话框的代码是:

var $aboutDialog = $("#aboutDialog")
    .dialog({
    autoOpen: false,
            draggable: false,
            width: 640,
            height: 'auto',
            resizable: false,
            position: 'center',
            modal: true,
            zIndex: 4,
            buttons: [
                {
                    text: "Ok",
                    click: function() { $(this).dialog("close"); }
                }
            ]

});

我包含的文件如下:

    <link rel="stylesheet" href="${resource(dir:'css',file:'960.css')}" />
    <link rel="stylesheet" href="${resource(dir:'css',file:'jquery-ui.css')}" />
    <g:layoutHead />
    <g:javascript library="jquery-1.5.1.min" />
    <g:javascript library="jquery-ui-1.8.10.custom.min" />

Opera 可以正确渲染,但 FireFox 4 和 Google Chrome 9 不能

完整的html:

<html>
<head>
    <title>Index</title>
    <link rel="shortcut icon" href="/images/favicon.ico" type="image/x-icon" />
    <link rel="stylesheet" href="/css/960.css" />
    <link rel="stylesheet" href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.1/themes/base/jquery-ui.css">


    <meta name="layout" content="main"/>

    <script type="text/javascript" src="/js/jquery-1.5.1.min.js"></script>

    <script type="text/javascript" src="/js/jquery-ui-1.8.10.custom.min.js"></script>

    <script type="text/javascript" src="/js/dialogs.js"></script>

</head>
<body>

<div id="header" class="container_24">
    <div class="grid_9"><h1>Title</h1></div>
    <nav class="grid_15">
        <ul>
            <li>My Gripes</li>
            <li>Categories</li>
        </ul>

        <form>
            <input type="search" />
            <input type="submit" value="search" />
        </form>
    </nav>
</div>

<div id="body" class="container_24">
    <div id="sidebar" class="grid_4">

        <a href="#"><img src="/images/logo.png" id="gripeBunny"  /></a>
        <br />
        <nav>
            <ul>
                <li><a id="openAbout" href="#">About</a></li>
                <li><a id="openPrivacy" href="#">Privacy</a></li>
            </ul>
        </nav>

    </div>
    <div id="content" class="grid_20">
        <h1>Hello World</h1>
    </div>


 </div>


    <div id="aboutDialog" title="About">
        About content goes here
    </div>

    <div id="privacyDialog" title="Privacy">
        Privacy statement
    </div>

</body>

这显示了对话框当前在 FireFox 4 和 Chrome 9 中的呈现方式。 当前如何呈现对话框的插图

这是该对话框在 Opera 中的显示方式以及我希望它在所有浏览器中的显示方式:

歌剧中正确的对话框渲染

4

2 回答 2

2

我遇到了类似的问题。我的问题是我使用的 jqueryui css 和 js 库不是同一个版本。看起来你正在做同样的事情。

尝试通过以下方式导入 jqueryui,它应该可以解决您的问题:

<link rel="stylesheet" href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.12/themes/base/jquery-ui.css" />
<script src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.8.12/jquery-ui.min.js"></script>
于 2011-05-10T08:23:30.050 回答
0

我有同样的问题。我停止使用 google 进行 jquery 托管,并从 jquery.com 下载了最新版本。

于 2011-07-22T04:55:18.487 回答