- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 jquery mobile 并在 <form>
中我有“保存”和“编辑”按钮( <a>
带有 data-role="button"
的标签)。单击保存按钮后,将打开一个对话框/确认。在这个对话框中是通常的确认/取消选项。
我想要发生的是单击“确认”并使用 data-rel="back"
要返回表单页面,我希望禁用保存按钮并启用默认情况下禁用的编辑按钮。
HTML:
<!--save button--><a class="save_button" data-role="button" href="save.html" data-rel="dialog" data-transition="pop">Save/Enter Line-Up</a>
<!--edit button--><a class="edit_button" data-role="button" href="edit.html" data-rel="dialog" data-transition="pop">Edit Line-Up</a>
(保存.html):
<div data-role="content">
<p>Do You Want To Save?</p>
<a class="confirm_button" href="#" data-role="button" data-rel="back">Confirm</a>
<a class="cancel_button" href="#" data-role="button" data-rel="back">Cancel</a>
</div><!-- /content -->
JS:
$(document).ready(function() {
$('.edit_button').addClass('ui-disabled');
/*edit button*/
$('.confirm_button').on("click", function() {
$('.edit_button').removeClass('ui-disabled');
$('.save_button').addClass('ui-disabled');
});
});
我无法让它工作。如果我不离开页面(即如果确认按钮与保存和编辑按钮位于同一页面上),上面的 JS 就可以工作。但是一旦我打开对话框,它就不起作用了。
在此先感谢您的帮助。
最佳答案
你没有提到一件大事。据我所知,您正在使用多个 html 文件。也许您不知道,但 jQuery Mobile 的工作方式与其他页面略有不同。主要是当第一页加载时,其全部内容将加载到 DOM(HEAD 和 BODY)中。但只有 BODY 会从其他页面加载。如果您考虑一下,这是正常情况,如果 DOM 中已经有一个 HEAD,则不需要加载其他页面的 HEAD-s。
在您的情况下,如果您的 javascript 在您的页面之间是分开的,那么如果它被放置在 HEAD 中,它将被丢弃(与其余的 HEAD 内容一起)。 <强> Here 您可以找到解决方法。
如果您所有的 javascript 都已放在第一个 HTML 文件中,那么您就会遇到另一个问题。在 jQuery Mobile 中绑定(bind)事件时,建议使用委托(delegate)绑定(bind)。基本上看看你的代码:
$('#confirmButton').on('click', function(){
});
如果在该按钮加载到 DOM 之前绑定(bind)此事件,则之后它将不起作用。为了解决这个问题,我们需要使用委托(delegate)绑定(bind),在这种情况下,元素是否存在于 DOM 中并不重要,因为事件绑定(bind)到某个 perenet 元素或更好的文档:
$(document).on('click', '#confirmButton',function(){
});
最后一件事。如果可能,请不要使用 jQuery Mobile 的 document ready,有时它会在页面加载到 DOM 之前触发。但是有一个解决办法。 jQuery Mobile 开发人员创建了页面事件来解决这个问题。 <强> Here 您可以阅读更多相关信息。
还有一件事,有 3 种类型的 jQuery Mobile 按钮和 2 种禁用它们的方法(不仅仅是一种),阅读更多相关信息 here .
关于javascript - 在对话框按钮上使用 ui-disabled,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16729262/
我使用 jQuery 禁用选择下拉列表中的选项。我需要知道使用之间的区别 prop('disabled','disabled') 和 prop('disabled',true) 两者几乎都适用于所有浏
.attr('disabled', 'disabled') 和 .attr('disabled', true) 在我的代码中都有效,但我只是想知道:两者中哪一个更有效和/或哪一个更常用?真的有区别吗?
我的 asp.net mvc View 中有以下脚本:- function disableform(id) { $('#' + id).prop("disabled", true); } 但是
我已经在 Oracle VM Ware 中为我的 ubuntu 可信操作系统安装了 visual studio 代码和依赖项。我用这些命令运行代码。 ssh -X myserver code 但是当我
我有这个函数可以切换输入字段的禁用属性: $('.someElement').click(function(){ if (someCondition) { console.log
自从前几天我升级了 angularjs 后,我一直收到警告。每当我打开 ui.bootstrap 模式时,它都会发生。 这是我在 chrome-beta 44 中收到的警告: angular.js:1
我想限制用户在单击特定按钮时在文本框中输入值,否则设置禁用 false。如果我设置 $("#txtquery").attr("disabled","disabled"); 它将文本框设置为空白。如果切
How do I make a Spinner's "disabled" state look disabled? 可能重复. 我尝试了帖子中提到的解决方案,即 ((Spinner) spinner)
这段代码: $tds = $(this).closest('tr').find(td input,select); $tds.attr('disabled','disabled'); 使我的表格行不
使用 jQM 1.4.0我试图覆盖灰色样式(): input[type="text"]:disabled { opacity: 1.0 !important; color: black
不知道为什么这不起作用。 当人们单击我的应用程序的“编辑”按钮时,禁用的文本字段将变为可编辑: $("#bewerken").click(function(e) { $("input[d
我对以下差异有些困惑: swiftlint:disable:next swiftlint:disable:this 最佳答案 它们都用于禁用单行的快速规则。您还可以为单行启用规则。来自 SwiftLi
我看到一些代码 # pylint: disable=W0123 还有一些 # pylint: disable-msg=W0123 它们只是同义词吗? 最佳答案 从 pylint 0.21.0 开始不推
默认情况下,在桌面上,flutter 中的 btns 在禁用时会更改鼠标光标: 我们想禁用此行为,或替换为不同的光标。 最佳答案 要覆盖 ElevatedButton、TextButton 或 Out
我一直在学习很多关于标准 asp.net 验证器的知识,我的最新发现是关于如何禁用验证器客户端,这非常酷。 现在,如果我的初始帖子启用了验证器,但在客户端,我禁用它,服务器端是否识别客户端更改并保留它
默认情况下,在桌面上,flutter 中的 btns 在禁用时会更改鼠标光标: 我们想禁用此行为,或替换为不同的光标。 最佳答案 要覆盖 ElevatedButton、TextButton 或 Out
这个问题在这里已经有了答案: Should I use CSS :disabled pseudo-class or [disabled] attribute selector or is it a
我有一个 python 脚本,它发送包含文本、html 和 ics 附件的多部分电子邮件。这个想法是,现代电子邮件客户端将呈现 HTML 部分并提供将事件添加到用户日历中的功能。 代码如下: impo
我有一个最初被禁用的按钮: Lorem ipsum 对于此按钮,button.getAttribute('disabled') 返回 "disabled"。但是,当我使用 JavaScript 启用此
在我的一些测试中,我必须确认在设置某些标志时某些 select2 下拉菜单被禁用。为了证实这一点,我发现以下策略似乎有效: Assert.True(element.GetAttribute("disa
我是一名优秀的程序员,十分优秀!