$ .mobile.changePage在一个非常简单的jQuery Mobile页面中的奇怪行为

时间:2012-02-25 14:26:33

标签: jquery-mobile

我正在使用jQuery mobile(和Phonegap,但以下是设备无关的)为移动设备编写Html 5应用程序,使用一个包含各种&lt; div data-role =&#34; page&的html页面#34; ...&gt;元素作为子页面。要在一个子页面和另一个子页面之间切换,我使用$ .mobile.changePage。 一切正常除非我将div标记放入其中一个&lt; div data-role =&#34; content&#34;&gt;容器<!/强>

工作示例:

<!DOCTYPE html>
<html>
<head>
    <title>App</title>
    <link rel="stylesheet" href="http://code.jquery.com/mobile/1.0/jquery.mobile-1.0.min.css" />
    <script src="http://code.jquery.com/jquery-1.6.4.min.js"></script>
    <script src="http://code.jquery.com/mobile/1.0/jquery.mobile-1.0.min.js"></script>
    <script type="text/javascript">
        $(document).ready(function() {
            $.mobile.changePage($('#page2'), {
                transition : 'slideup',
                reverse : false,
                changeHash : true
            });
        });

    </script>
</head>
<body>
    <div data-role="page" id="page1" data-theme="a">
        <div data-role="content">
            Page1
        </div>
    </div>
    <div data-role="page" id="page2" data-theme="a">
        <div data-role="content">
            Page2
        </div>
    </div>
</body>
</html>

现在,在Page1

后面添加一个简单的封闭div标签之后
Page1 -> Page1<div />

$ .mobile.changePage仍然会触发 - 可以看到page2内容一秒钟 - 但随后会显示一个空白屏幕。

这种情况发生在桌面浏览器和智能手机中(使用Phonegap并调整代码)。

我真的很感激任何想法或提示。缩小这个问题并使其单独再现可以花费我数小时的宝贵时间,因为它似乎不太可能......

1 个答案:

答案 0 :(得分:4)

更改

Page1<div />

Page1</div>

...

Page1<div>test</div> 

也有效。

不确定为什么jqm在空div上尾随/有问题。