gpt4 book ai didi

jquery - 单击模式中的按钮时,尝试更改启动模式的按钮的属性

转载 作者:行者123 更新时间:2023-12-01 04:35:41 24 4
gpt4 key购买 nike

我有一个带有一些数据属性的按钮。当我单击它时,会显示一个模式。在这个模式中,我有一个按钮可以更新数据库并关闭模式。我需要更改单击的按钮中的数据属性以显示模式。有人有建议吗?请参阅最后一行代码。 e.latedTarget 在这里不起作用。

$(document).on('show.bs.modal','#myModal', function (e) {
$('#textareaID').val($(e.relatedTarget).data('text')); //the data attribute used here I need to change later
$('#listID').val($(e.relatedTarget).data('listid'));
});

$(document).on('hide.bs.modal','#myModal', function (e) {
//Clearing values before next use of modal
$('#textareaID').val('');
$('#listID').val('');
});

$(document).on('click', '#btnSave', function(e) {
var id = $('#listID').val();
var text = $('#textareaID').val();

//code here to update DB

//Now need to set the data-text attribute value to "text" variable.
$(e.relatedTarget).data('text', text); // NOT WORKING!
}

最佳答案

这样的事情应该可以工作,向打开模式的按钮添加一个类,然后在保存模式时只需替换数据属性并删除“打开”类。

var modal = $('.modal');
var btn = null;
$(document).on('click', '.open-modal', function(e) {
btn = $(this);
btn.addClass('opened-modal');
modal.show();
modal.find('.modal-header').append('Clicked: ' + $(this).html());
$(document).on('click', '#btnSave', function(e) {
var text = $('#myInput').val();

// code here to update DB

// Now need to set the data-text attribute value to "text" variable.
btn.attr('data-text', text);
btn.removeClass('opened-modal');
modal.hide();
});
$(document).on('click', '#btnClose', function(e) {
var btn = null;
modal.hide();
});
});
.modal {
display: none;
background: rgba(0, 0, 0, 0.5);
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<button class="open-modal" data-text="button">one</button>
<button class="open-modal" data-text="button">two</button>
<button class="open-modal" data-text="button">three</button>
<button class="open-modal" data-text="button">four</button>
<div class="modal" tabindex="-1" role="dialog">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title">Modal</h5>
<input id="myInput" type="text">
</div>
<div class="modal-footer">
<button type="button" id="btnSave" data-dismiss="modal">add-attr</button>
<button type="button" id="btnClose" data-dismiss="modal">close</button>
</div>
</div>
</div>
</div>

关于jquery - 单击模式中的按钮时,尝试更改启动模式的按钮的属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57009100/

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