IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

jQuery Discussion :

UI Droppable, limiter le nombre d'élément


Sujet :

jQuery

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Octobre 2008
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 31
    Par défaut [Résolu] UI Droppable, limiter le nombre d'élément
    Bonjour,

    Je rencontre un problème. Je ne sais pas du tout comment limiter mon nombre de drop a 3.

    merci de votre aide.

    mon html :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    <body>
    <div id="droppable"></div>
    <div id="draggable">
         <li id="1">item1</li>
         <li id="2">item1</li>
         <li id="3">item1</li>
         <li id="4">item1</li>
        .........
    </div>
    </body>
    je ne sais même pas si c est la bonne méthode ou si il faut plutôt utiliser la fonction sortable ...
    mon javascript :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
     
    $(function(){
    var q7=$("#1,#2,#3,#4,#5,#6,#7,#8,#9,#10");
    $.each(q7,function(){
    	$(this).draggable({ revert: 'invalid' });
    });
     
    var limit = 3;
    var nbdrop = 0;
     
    $("#droppable").droppable({
    			accept: ".1",
    			tolerance: 'fit',
    			drop: function(event, ui) {
    			nbdrop++;
    			//alert(nbdrop);
    			var objet_drop = $(ui.draggable); // L'élément drop 
                var nameid = objet_drop.attr('id'); // ID de l'élément drop 
    			$.get("ajax/ajou.php",{statut:"add",id:nameid});
    			}
     
    		});
     
    		$("#draggable").droppable({
     
    			drop: function(event, ui) {
    			nbdrop--;
    			var objet_drop = $(ui.draggable); // L'élément drop 
                var nameid = objet_drop.attr('id'); // ID de l'élément drop 
    			$.get("ajax/ajou.php",{statut:"sup",id:nameid});
    			}
    		});
     
     
    });

  2. #2
    Rédacteur

    Avatar de danielhagnoul
    Homme Profil pro
    Étudiant perpétuel
    Inscrit en
    Février 2009
    Messages
    6 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant perpétuel
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 6 389
    Billets dans le blog
    125
    Par défaut
    Bonsoir.

    Pour limiter le nombre d'élément droppable :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr">
    <head>
    	<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    	<meta name="Author" content="Daniel Hagnoul" />
    	<title>Page type</title>
    	<link rel="stylesheet" type="text/css" href="../lib/humanity/jquery-ui-1.7.2.custom.css" media="screen" />
    	<style type="text/css">
    		body {
    			background-color:#696969;
    			color:#000000;
    			font-family:Arial, Helvetica, sans-serif;
    			font-size:medium;
    			font-style:normal;
    			font-weight:normal;
    			line-height:normal;
    			letter-spacing:normal;
    		}
    		h1,h2,h3,h4,h5 {
    			font-family:"Times New Roman", Times, serif;
    		}
    		div,p,h1,h2,h3,h4,h5,h6,ul,ol,dl,form,table,img {
    			margin:0px;
    			padding:0px;
    		}
    		p {
    			padding:6px;
    		}
    		ul,ol,dl {
    			list-style:none;
    			padding-left:6px;
    			padding-top:6px;
    		}
    		li {
    			padding-bottom:6px;
    		}
    		div#conteneur {
    			width:95%;
    			margin:12px auto;
    			padding:6px;
    			background-color:#FFFFFF;
    			color:#000000;
    			border:1px solid #666666;
    			font-size:0.8em;
    		}
     
    		/* TEST */
    		div#droppable {
    			float:right;
    			width:300px;
    			height:300px;
    			background-color:#00ffcc;
    			border:1px solid black;
    		}
    		div#draggable li {
    			display:block;
    			width:100px;
    			height:50px;
    			background-color:yellow;
    			margin:12px;
    			padding:6px;
    		}
    	</style>
    	<script type="text/javascript" src="../lib/jquery-1.3.2.min.js"></script>
    	<script type="text/javascript" src="../lib/jquery-ui-1.7.2.custom.min.js"></script>
    	<script type="text/javascript">
    		$(document).ready(function(){
    			var nbdrop = 0;
     
    			$("#droppable").droppable({
    				accept:function(){
    					if (nbdrop < 3) {
    						return true;
    					}
     
    					return false;
    				},
    				drop: function(event, ui){
    					nbdrop++;
    					$("#affiche").html("nbdrop = " + nbdrop);
    				}
    			});
     
    			$("#draggable li").draggable({
    				revert:"invalid"
    			});
     		});
     	</script>
    </head>
    <body>
    	<div id="conteneur">
    		<div id="droppable"></div>
    		<div id="draggable">
    			 <li id="1">item 1</li>
    			 <li id="2">item 2</li>
    			 <li id="3">item 3</li>
    			 <li id="4">item 4</li>
    		</div>
    		<div id="affiche" style="clear:both;"></div>
    	</div>
    </body>
    </html>

    Blog

    Sans l'analyse et la conception, la programmation est l'art d'ajouter des bogues à un fichier texte vide.
    (Louis Srygley : Without requirements or design, programming is the art of adding bugs to an empty text file.)

  3. #3
    Membre averti
    Inscrit en
    Octobre 2008
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 31
    Par défaut
    ouep c est ce qu'un gars ma montré sur un autre forum.

    merci de votre aide ca marche nickel.

    dans la doc c'était écrit callback fonction mais je trouvais pas d exemple pour la mettre en oeuvre

    l'option importante :

    accept: function(draggable) {
    return nbdrop < 3;
    },


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
     
    $(function(){
    var q7=$("#1,#2,#3,#4,#5,#6,#7,#8,#9,#10");
    $.each(q7,function(){
    	$(this).draggable({ revert: 'invalid' });
    });
     
    var limit = 3;
    var nbdrop = 0;
     
    $("#droppable").droppable({
    			accept: function(draggable) {
    					return nbdrop < 3;
    					},
    			tolerance: 'fit',
     
    			drop: function(event, ui) {
    			nbdrop++;
    			//alert(nbdrop);
    			var objet_drop = $(ui.draggable); // L'élément drop 
                var nameid = objet_drop.attr('id'); // ID de l'élément drop 
    			$.get("ajax/ajou.php",{statut:"add",id:nameid});
    			}
     
    		});
     
    		$("#draggable").droppable({
     
    			drop: function(event, ui) {
    			nbdrop--;
    			var objet_drop = $(ui.draggable); // L'élément drop 
                var nameid = objet_drop.attr('id'); // ID de l'élément drop 
    			$.get("ajax/ajou.php",{statut:"sup",id:nameid});
    			}
    		});
     
     
    });

Discussions similaires

  1. Limiter le nombre d'éléments d'un menu
    Par soso78 dans le forum ASP.NET
    Réponses: 1
    Dernier message: 22/01/2008, 16h29
  2. [JTextArea] limiter le nombre de caractères
    Par spoutyoyo dans le forum Composants
    Réponses: 5
    Dernier message: 14/09/2007, 15h45
  3. [MFC] Limitation du nombre de fichiers...
    Par chronos dans le forum MFC
    Réponses: 5
    Dernier message: 02/06/2004, 10h40
  4. Limiter le nombre d'enregistrement
    Par BXDSPORT dans le forum Bases de données
    Réponses: 2
    Dernier message: 22/04/2004, 16h26
  5. [débutant] Limitation du nombre d'enregistrement renvoyé
    Par tmcgrady dans le forum Langage SQL
    Réponses: 4
    Dernier message: 12/11/2003, 09h41

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo