gpt4 book ai didi

javascript - onchange javascript 在 jquerymobile 中提交换行符

转载 作者:行者123 更新时间:2023-11-28 02:13:28 24 4
gpt4 key购买 nike

我正在使用这样的 JavaScript...

<select onchange="document.langForm.submit();" ... >

但是当我开始使用 jquerymobile 时,它​​就崩溃了。

我知道这个问题之前已经出现过 100 次了。但之前案例的超链接在这里没有帮助,因为我已经阅读了几十本,不幸的是我不够聪明,无法理解任何其他讨论。严重地。我完全困惑了。

另一方面,我花了时间做了一个非常非常简单的例子来展示我的头痛。因此,如果有人能准确地告诉我如何修复这两个页面,我将不胜感激。

http://activemetrics.ch/test/en.html

http://activemetrics.ch/test/de.html

请注意,您可以在浏览器中加载其中一个页面,然后通过更改选择列表中的选择切换到另一个页面。但是,进入第二页后,您无法使用类似的操作返回第一页。

是的,这与ajax有关。我知道的就这么多。但是对我来说解决这两个页面上的问题以允许用户轻松地在两个页面之间来回切换的最佳方法是什么?

欢迎所有建议。

非常感谢那些花点脑电波为我考虑这个问题的人!

-jd

最佳答案

描述:

要了解这种情况,您需要了解 jQuery Mobile 的工作原理。它使用ajax来加载其他页面。

第一页正常加载。它的 HEADBODY 被加载到 DOM 中>,他们在那里等待其他内容。加载第二个页面时,仅将其 BODY 内容加载到 DOM 中。

从我在你的回答中得到的信息来看,你明白这一点,但你犯了一个错误。有 2 个 html 文件:en.htmlde.html 但它们的名称并不重要。重要的是页面 id 或 data-role="page" div 的 id 属性。在您的情况下,您有 2 个页面具有相同的 div 和相同的选择 id。因为它们都加载到 DOM 事件绑定(bind)将始终转到第一个加载的页面。

您需要为您的页面和选择框使用唯一的 ID。

工作示例:

en.html

<!DOCTYPE html> 
<html>
<head>
<title>My Page</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://code.jquery.com/mobile/1.2.1/jquery.mobile-1.2.1.min.js"></script>
</head>
<body>
<div data-role="page" id="sbePage1">
<h3>this is english</h3>
<form name="langForm" id="langForm" action="BookNow.asp?" method="get" style="margin-top:0px auto">
<select data-inline="true" name="lang" id="langId" data-native-menu="false" >
<option value="1972" SELECTED>Something Already Selected</option>
<option value="1973">Some Sort of Change</option>
</select>
</form>
<script>
$(document).on('pageinit', '#sbePage1' ,function () {
$(document).off('change', '#langId').on('change', '#langId',function (event) {
$.mobile.changePage('de.html', {
type: 'get',
data: ''
});
});
});
</script>
</div><!-- /page -->
</body>
</html>

de.html

<!DOCTYPE html> 
<html>
<head>
<title>My Page</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://code.jquery.com/mobile/1.2.1/jquery.mobile-1.2.1.min.js"></script>
</head>
<body>
<div data-role="page" id="sbePage2">
<h3>this is german</h3>
<form name="langForm2" id="langForm2" action="BookNow.asp?" method="get" style="margin-top:0px auto">
<select data-inline="true" name="lang" id="langId2" data-native-menu="false" >
<option value="1972" SELECTED>Something Already Selected</option>
<option value="1973">Something Else</option>
</select>
</form>
<script>
$(document).on('pageinit', '#sbePage2' ,function () {
$(document).off('change', '#langId2').on('change', '#langId2',function (event) {
$.mobile.changePage('en.html', {
type: 'get',
data: ''
});
});
});
</script>
</div><!-- /page -->
</body>
</html>

编辑:

虽然我理解你的愿望,但我还是必须告诉你,这是不可能的。在当前示例中,jQuery Mobile 不能有 2 个具有相同 id 的页面。想想看,您将有 2 个具有相同 id 的页面加载到 DOM 中。每次尝试访问页面 DIV 时,您将始终访问第一页,因为它位于队列的第一页。

如果您想创建多语言页面,则不需要多个 html 页面。只需寻找一个好的 jQuery 多语言插件即可。

另一方面,如果你关闭ajax,你可以做你想做的事,但你会失去动画过渡。

没有 ajax 但页面具有相同 id 的示例

en.html:

<!DOCTYPE html> 
<html>
<head>
<title>My Page</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 language="text/javascript">
$(document).bind("mobileinit", function () {
$.mobile.ajaxEnabled = false;
});
</script>
<script src="http://code.jquery.com/mobile/1.2.1/jquery.mobile-1.2.1.min.js"></script>
</head>
<body>

<div data-role="page" id="sbePage1en">
<h3>this is english</h3>
<form name="langFormEn" id="langFormEn" action="BookNow.asp?" method=get style="margin-top:0px auto">
<select data-inline="true" name="lang" id="langId" data-native-menu="false" >
<option value="1972" SELECTED>Something Already Selected</option>
<option value="1973">Some Sort of Change</option>
</select></form>
<script>
$("#sbePage1en").live('pageshow', function () {
$('#langFormEn').bind('change', function (event) {
$.mobile.changePage('de.html', {
type: 'get',
data: ''
});
});
});
</script>
</div><!-- /page -->
</body>
</html>

de.html

<!DOCTYPE html> 
<html>
<head>
<title>My Page</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 language="text/javascript">
$(document).bind("mobileinit", function () {
$.mobile.ajaxEnabled = false;
});
</script>
<script src="http://code.jquery.com/mobile/1.2.1/jquery.mobile-1.2.1.min.js"></script>
</head>
<body>

<div data-role="page" id="sbePage1de">
<h3>this is german</h3>
<form name="langFormDe" id="langFormDe" action="BookNow.asp?" method=get style="margin-top:0px auto">
<select data-inline="true" name="lang" id="langId" data-native-menu="false" >
<option value="1972" SELECTED>Something Already Selected</option>
<option value="1973">Something Else</option>
</select></form>
<script>
$("#sbePage1de").live('pageshow', function () {
$('#langFormDe').bind('change', function (event) {
$.mobile.changePage('en.html', {
type: 'get',
data: ''
});
});
});
</script>
</div><!-- /page -->
</body>
</html>

关于javascript - onchange javascript 在 jquerymobile 中提交换行符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16742812/

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