我想要实现的是一个div中有几个按钮的页面。当用户按下其中一个按钮时,会打开一个对话框,询问后续问题。在此之后,用户返回到同一页面,但隐藏了带按钮的div。
我尝试的是以下内容,在JQM页面中我有div,其中包含按钮(逻辑上)。这将打开对话框,并调用一个函数,该函数将按下按钮保存到本地存储器。然后打开对话框,实际将数据发送到服务器。
由于某种原因,当我从对话框返回时,div永远不会被隐藏。我甚至试图将一个变量保存到sessionStorage并隐藏pageload上的div,但似乎从对话框返回时页面加载事件不会触发。有什么建议或者我遗漏了一些基本的东西吗?
<div class="ui-grid-b" id="buttons">
<div class="ui-block-a"><a href="#Popup" data-rel="dialog" onclick="savePushedButton('green')"></a></div>
<div class="ui-block-b"><a href="#Popup" data-rel="dialog" onclick="savePushedButton('yellow')"></a></div>
<div class="ui-block-c"><a href="#Popup" data-rel="dialog" onclick="savePushedButton('red')"></a></div>
</div><!-- /grid-b -->
// the dialog:
<div data-role="dialog" id="Popup" data-overlay-theme="b" data-theme="a" class="ui-corner-all">
<form>
<div style="padding:10px 20px;">
<h3>Heading</h3>
<textarea name="comments" id="popuptextarea"></textarea>
<button type="submit" data-theme="b" onClick="save()">Selvä</button>
</div>
</form>
</div>
我有两个javascript函数试图保存数据并隐藏div,
function savePushedButton(color) {
//save which button was pressed to local storage
$('#buttons').hide();
console.log("asd");
}
function save() {
//send data to server
}
答案 0 :(得分:0)
onclick 是你的问题( onchange 也是如此),请不要将它与jQuery Mobile一起使用。在触发 onclick 之前,jQuery Mobile已经开始转换到对话框。在转换到对话框之前,您需要手动将单击事件绑定到按钮并隐藏按钮。
以下是一个有效的例子:http://jsfiddle.net/Gajotres/uhsfs/
$(document).on('pagebeforeshow', '#index', function(){
$(document).on('click', '#test-button', function(){
$('#buttons').hide();
savePushedButton($(this).attr('data-color'));
});
});
function savePushedButton(color) {
console.log(color);
$.mobile.changePage('#Popup', {transition: 'pop', role: 'dialog'});
}