1

我有一个包含两个 html 页面(bmi.html 和 7min.html)和一些 javascript 的项目...我使用页脚在页面之间导航。

  • 第一个问题:第一次运行 7min.html,使用页脚导航到 bmi.html,bmi 中的 javascript 不起作用!
  • 第 2 期:第一次运行 bmi.html,导航到 7min.html 并再次返回 bmi。Javascript 工作正常,但关闭弹出对话框后返回 7 分钟页面。

下面是我的代码。

7分钟:http: //jsfiddle.net/Rwf5G/ bmi:http: //jsfiddle.net/snKyK/

<html>

<head>
    <meta charset="utf-8">
    <title>Body Trainer</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">

    <link rel="stylesheet" href="http://code.jquery.com/mobile/1.2.1/jquery.mobile-1.2.1.min.css" />

    <script src="http://code.jquery.com/jquery-1.8.3.min.js"></script>
    <script src="http://jquerymobile.com/demos/1.2.1/docs/_assets/js/jqm-docs.js"></script>
    <script src="http://jquerymobile.com/demos/1.2.1/js/jquery.mobile-1.2.1.js"></script>

</head>

<body>

    <div data-role="page" id="7min-page" class="type-interior" >

        <div data-role="header" data-position="fixed" data-id="appHeader" >
            <h1>Workout</h1>
        </div><!-- /header -->

        <div data-role="content" >
            <h4>Brief</h4>
            <p>
                Some bla bla...
            </p>


        </div>

        <div data-role="footer" data-id="appFooter" data-position="fixed">
            <div data-role="navbar">
                <ul>
                    <li>
                        <a href="bmi.html" data-prefetch="true">BMI</a>
                    </li>
                    <li>
                        <a href="7min.html" data-prefetch="true" class="ui-btn-active ui-state-persist">7min</a>
                    </li>
                </ul>
            </div><!-- /navbar -->
        </div><!-- /footer -->

    </div>

</body>

(很抱歉我使用了jsfiddle,在这里添加代码时遇到了一些问题。)

4

1 回答 1

1
  1. 首要问题:

    jQuery Mobile 使用 Ajax 导航系统来加载页面和更改视图/页面。当您从bmi.html开始时,将加载所有 HTML 标记。当您从bmi.html导航到7min.html时,jQuery Mobile 只加载<div data-role="page"></div>其中的内容。data-role=page它忽略了div之外的其他 HTML 标签。

    • 解决方案:将JS代码放在<div data-role="page"></div>.
    • 选项:要在不使用 AJAX 的情况下导航,请添加rel="external"data-ajax="false"锚标记。这样做会正常加载页面,但是,您将失去页面转换效果。
  2. 第二题:

    将此属性添加data-history="false"<div data-role="popup">div。

于 2013-10-09T11:01:01.007 回答