我在模态中得到了一个表单,当它提交时我不希望它关闭。他们的方式我得到我的SQL UPDATE语句设置是如果日期库更新,它将重定向到同一页面,所以这在试图保持模态打开时搞乱了很多东西。
if (isset($_POST['insert6']))
{
$kval_antall = $_POST['kval_antall'];
$id = $_POST['id'];
$sql6 = ("UPDATE test3 SET kval_antall='$kval_antall' WHERE id='$id'");
if (mysqli_query($conn, $sql6)) {
header("Location: aktivbonus.php");
exit;
} else {
echo "Error: " . $sql6 . "<br>" . mysqli_error($conn);
}}
因为如果我之前放了一些代码并保持模态打开,如果数据在数据库中成功更新,它将返回到同一页面并关闭模态。在重定向后,我无法找到打开模态的方法。
这是我尝试过的一些东西:(主教回答)How to redirect back to index page and display modal pop up as per redirecting? PHP
在提交表单并重定向回来之后,代码可以正常工作并显示消息,但是当我插入时,没有任何反应:
<?php if (isset($_GET['thanks']) && 1 == $_GET['thanks']) { ?>
<script type='text/javascript'>
$("#message539").modal("show");
</script>
<?php } ?>
我让我的网站工作的方式是页面上出现一个带有data-target="#message539"
的按钮
与其尝试调用的模态相同(此处相同的ID更改):
<div class="modal fade bd-example-modal-lg" id="message'. $row['id'] .'" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">
在这个改变它的模式#message539,我试图打电话。如果有人有这样做的好方法,非常感谢帮助,因为我现在因为尝试了许多不同的事情而失去了兴趣。
我尽力解释我想要的东西而且很难理解,所以请问一下有什么不清楚的地方。谢谢。
资本
<?php
while ($row = mysqli_fetch_assoc($result)) {
$test55 = '<div class="card card-date"><div class="card-body card-body-date text-secondary"><h5>' . strftime('%e.%B',strtotime($row['date'])) . ' <div class="card-header-date"><i class="material-icons">arrow_downward</i></div></h5></div></div>';
echo $test55 !== $prevDate ? $test55.'' : '';
$prevDate = $test55;
echo '
<div class="card border-info card-margin">
<h5 class="card-header text-secondary">
'. $row['bookmaker']. ': '. $row['bettype']. ' '. $row['betvalue']. 'kr <div class="card-header-date">Dato lagt til: Kl.'. strftime('%H:%M, %e.%b',strtotime($row['date2'])) . '</div>
</h5>
<div class="card-body text-secondary">
<h5 class="card-title">Status:</h5>
<p class="card-text">' . $row ['status'] . '</p>
</div>
<div class="card-footer bg-transparent"><div class="text-right"><button type="button" class="btn btn-outline-info" data-toggle="modal" data-target="#message'.$row['id'].'">Endre</button></div></div> <-- BUTTON THAT OPENS THE MODAL
</div>
</div>
<div class="modal fade bd-example-modal-lg" id="message'. $row['id'] .'" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true"> <--- MODAL
<div class="modal-dialog modal-lg" role="document">
<div class="modal-content">
<div class="modal-header card-header">
<h5 class="modal-title text-secondary" id="exampleModalLabel">'.$row['bookmaker'].': '.$row['bettype'].' '.$row['betvalue'].'kr</h5><div class="text-secondary" style="font-size: 1.25rem;font-weight: 500;">Dato lagt til: '.strftime('%H:%M, %e.%b',strtotime($row['date2'])).'</div>
</div>
<div class="modal-body">
当您进入重定向页面时,您可以使用localStorage跟踪是否需要打开模式:
调用更新函数时:
localStorage.setItem('openModal', '#message539'); // Use message'. $row['id'] to dinamically save it
加载页面时:
var modalId = localStorage.getItem('openModal');
if (modalId != null){
$(modalId).modal("show");
localStorage.removeItem('openModal');
}
使用javascript或jQuery执行此操作:在重定向时发送成功标志,并在重定向页面上检查该标志是否为真,而不是使用jQuery显示模式,
例如:(查看页面)
$flag = $flag?1:0;
<button id="btn-modal-open" style="display:none">clcik</button>
并在jQuery函数中
$( document ).ready(function() {
var flag = "<?= $flag?>";
if(flag){
$('#btn-modal-open')[0].click(); //create one
//button and give id as btn-modal-open so that on
//click of button modal should popup
}
});
需要更多的解释而不是告诉我