Envoyer paramètre à Bootstrap fenêtre modale?
j'ai un problème, je ne peux pas passer des paramètres à une fenêtre modale (en utilisant Bootstrap 3), j'ai essayé d'utiliser la solution indiqué dans ce lien, mais je ne peux pas le faire fonctionner:
charger dynamiquement des informations sur Twitter Bootstrap modal
(Solution kexxcream de l'utilisateur).
mais en appuyant sur le bouton, l'affichage ne me montre rien, apparemment des blocs, attaché une image ci-dessous:
http://i.imgur.com/uzRUyf1.png
j'ai joint le code (même code post ci-dessus à gauche);
Code HTML:
<div id="myModal" class="modal hide fade">
<div class="modal-header">
<button class="close" data-dismiss="modal">×</button>
<h3>Title</h3>
</div>
<div class="modal-body">
<div id="modalContent" style="display:none;">
</div>
</div>
<div class="modal-footer">
<a href="#" class="btn btn-info" data-dismiss="modal" >Close</a>
</div>
</div>
Code JS:
$("a[data-toggle=modal]").click(function()
{
var essay_id = $(this).attr('id');
$.ajax({
cache: false,
type: 'POST',
url: 'backend.php',
data: 'EID='+essay_id,
success: function(data)
{
$('#myModal').show();
$('#modalContent').show().html(data);
}
});
});
Bouton:
<a href='#myModal' data-toggle='modal' id='2'> Edit </a>
Code PHP (backend.php):
<?php
$editId = $_POST['EID'];
?>
<div class="jumbotron">
<div class="container">
<h1>The ID Selected is <?php echo $editId ?></h1>
</div>
</div>
4 réponses
tout d'abord, vous devez corriger HTML modal structure. Maintenant ce n'est pas correct, vous n'avez pas besoin de classe .hide
:
<div id="edit-modal" class="modal fade" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
<h4 class="modal-title" id="myModalLabel">Modal title</h4>
</div>
<div class="modal-body edit-content">
...
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
<button type="button" class="btn btn-primary">Save changes</button>
</div>
</div>
</div>
</div>
alors les liens devraient pointer vers ce modal via data-target
l'attribut:
<a href="#myModal" data-toggle="modal" id="1" data-target="#edit-modal">Edit 1</a>
Enfin Js partie devient très simple:
$('#edit-modal').on('show.bs.modal', function(e) {
var $modal = $(this),
esseyId = e.relatedTarget.id;
$.ajax({
cache: false,
type: 'POST',
url: 'backend.php',
data: 'EID=' + essayId,
success: function(data) {
$modal.find('.edit-content').html(data);
}
});
})
Démo: http://plnkr.co/edit/4XnLTZ557qMegqRmWVwU?p=preview
Il y a une meilleure solution que la réponse acceptée, en particulier en utilisant les attributs data -*. Définir l'id à 1 provoquera des problèmes si un autre élément de la page a id=1. Au lieu de cela, vous pouvez faire:
<button class="btn btn-primary" data-toggle="modal" data-target="#yourModalID" data-yourparameter="whateverYouWant">Load</button>
<script>
$('#yourModalID').on('show.bs.modal', function(e) {
var yourparameter = e.relatedTarget.dataset.yourparameter;
// Do some stuff w/ it.
});
</script>
j'ai trouvé la solution à: la transmission des données à un modal bootstrap
Il suffit d'utiliser:
$(e.relatedTarget).data('book-id');
avec 'book-id
' est un attribut de modal avec pré-fix '
j'ai trouvé cette meilleure façon , pas besoin de supprimer des données, il suffit d'appeler la source du contenu distant à chaque fois
$(document).ready(function() {
$('.class').click(function() {
var id = this.id;
//alert(id);checking that have correct id
$("#iframe").attr("src","url?id=" + id);
$('#Modal').modal({
show: true
});
});
});