gpt4 book ai didi

javascript - jQuery Mobile "mobileinit"事件触发两次?

转载 作者:行者123 更新时间:2023-11-29 22:24:05 24 4
gpt4 key购买 nike

我的 index.html 看起来像这样:

<!DOCTYPE html>
<html class="ui-mobile-rendering">
<head>
<title></title>
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no;" />
<meta charset="utf-8">
<link rel="stylesheet" href="css/jquery.mobile-1.1.0.min.css" />
<list rel="stylesheet" href="css/app.css" />
<script src="js/jquery.min.js"></script>
<script type="text/javascript" src="js/underscore.js"></script>
<script type="text/javascript" src="js/backbone.js"></script>
<script type="text/javascript" src="js/views/attachmentlist.js"></script>
<script type="text/javascript" src="js/models/attachmentmodel.js"></script>
<script type="text/javascript" src="js/app.js"></script>
<script src="js/jquery.mobile-1.1.0.min.js"></script>
<script type="text/javascript" charset="utf-8" src="js/cordova-1.7.0rc1.js"></script>
</head>

<body></body>

</html>

绝对没有这些文件有对 jQuery Mobile 的引用,只有 Index 有。

我的 app.js 文件如下所示:

$(document).live("mobileinit", function () {
console.log('in Mobile Init');
$.mobile.ajaxEnabled = false;
$.mobile.linkBindingEnabled = false;
$.mobile.hashListeningEnabled = false;
$.mobile.pushStateEnabled = false;

// Remove page from DOM when it's being replaced
$('div[data-role="page"]').live('pagehide', function (event, ui) {
$(event.currentTarget).remove();
});
});

某些原因导致“mobile init”触发两次。我不确定它是什么,即使它真的是一个问题,但感觉像是不应该发生的事情。
有什么办法可以解决这个问题吗?

编辑
我实际上只是注意到,如果我将一个简单的“脚本”标签直接放入正文并在那里执行 console.log,它会运行两次......sooo......此代码中的某些内容导致我的整个页面被初始化两次。
事实上,我的整个设置实际上好像加载了两次。我将 console.logs 放在应用程序首次加载时发生的所有事情的链条中,并且一切都发生了两次。

最佳答案

我曾经遇到过类似的事情。对于它的值(value),这就是解决它的方式:

$(document).bind("mobileinit", function() {
$.extend( $.mobile , {
autoInitializePage: false,
loadingMessage: false
});
});

如果我必须使其适应您的代码,请尝试如下操作:

$(document).live("mobileinit", function () {
console.log('in Mobile Init');

$.extend( $.mobile , {
autoInitializePage: false,
loadingMessage: false
});

$.mobile.ajaxEnabled = false;
$.mobile.linkBindingEnabled = false;
$.mobile.hashListeningEnabled = false;
$.mobile.pushStateEnabled = false;

// Remove page from DOM when it's being replaced
$('div[data-role="page"]').live('pagehide', function (event, ui) {
$(event.currentTarget).remove();
});
});

附带说明一下,您不应该使用 jQuery 的 .live() 函数。根据自己docs :

As of jQuery 1.7, the .live() method is deprecated. Use .on() to attach event handlers. Users of older versions of jQuery should use .delegate() in preference to .live().

关于javascript - jQuery Mobile "mobileinit"事件触发两次?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10636266/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com