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

JavaScript Discussion :

différence sous IE vs FF


Sujet :

JavaScript

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 73
    Points : 62
    Points
    62
    Par défaut différence sous IE vs FF
    Bonjour à tous!
    J'ai un petit soucis... un problèment que je n'arrive pas du tout à comprendre

    J'ai un code ici qui permet de déplacer des div à l'aide de la souris. tout fonctionne bien sous IE (étonnant non? ) mais sous FF, c'est la que ça ce gâte...

    voici le code
    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
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    <html>
    <head>
    <style type="text/css">
    #dim1{
     border:1px solid red;
     position:absolute;
     left:100px;
     width:100px;
     top:100px;
     height:100px;
    }
    #dim2{
     border:1px solid blue;
     position:absolute;
     left:300px;
     width:100px;
     top:100px;
     height:100px;
    }
    div:hover{
     cursor:move;
    }
    body{
     cursor:n-resize;
    }
     
    </style>
    <script>
    var xinit; // position de la souris au clic sur le div
    var yinit;
    var x; // position de l'élément au départ
    var y;
    var initier = false; // si on est en train de cliquer
    var gauche = false; // si on a cliqué sur un bord gauche
    var droite = false; // si on a cliqué sur un bord droit
    var haut = false; // si on a cliqué sur un bord haut
    var bas = false; // si on a cliqué sur un bord bas
    var idEnCours; // id du div qui est en cours de modif
     
    function init(e, id){
     idEnCours = id;
     initier = true;
     xtmp = document.getElementById(id).offsetLeft;
     ytmp = document.getElementById(id).offsetTop;
     x = document.getElementById(id).offsetLeft;
     y = document.getElementById(id).offsetTop;
     xinit = e.clientX;
     yinit = e.clientY;
     
     // on test la position de la souris
     if(e.clientX >= xtmp && e.clientX <= xtmp+2){
      gauche = true;
      if(e.clientY >= ytmp && e.clientY <= ytmp+2){
       haut = true;
      }
      else if(e.clientY >= ytmp + document.getElementById(id).offsetHeight-2 && e.clientY <= ytmp + document.getElementById(id).offsetHeight){
       bas = true;
      }
     }
     else if(e.clientX >= xtmp + document.getElementById(id).offsetWidth-2 && e.clientX <= xtmp + document.getElementById(id).offsetWidth){
      droite = true;
      if(e.clientY >= ytmp && e.clientY <= ytmp+2){
       haut = true;
      }
      else if(e.clientY >= ytmp + document.getElementById(id).offsetHeight-2 && e.clientY <= ytmp + document.getElementById(id).offsetHeight){
       bas = true;
      }
     }
     else if(e.clientY >= ytmp && e.clientY <= ytmp+2){
      haut = true;
     }
     else if(e.clientY >= ytmp + document.getElementById(id).offsetHeight-2 && e.clientY <= ytmp + document.getElementById(id).offsetHeight){
      bas = true;
     }
    }
     
    function bouge(e){
     // si on a cliqué et qu'on bouge
     if(initier){
      xtmp = document.getElementById(idEnCours).offsetLeft;
      ytmp = document.getElementById(idEnCours).offsetTop;
      if(gauche){
       document.getElementById(idEnCours).style.left = e.clientX;
       document.getElementById(idEnCours).style.width = document.getElementById(idEnCours).offsetWidth + (xtmp - e.clientX);
       if(haut){
        document.getElementById(idEnCours).style.top = e.clientY;
        document.getElementById(idEnCours).style.height = document.getElementById(idEnCours).offsetHeight + (ytmp - e.clientY);
       }
       else if(bas){
        document.getElementById(idEnCours).style.height = document.getElementById(idEnCours).offsetHeight + (e.clientY - y - document.getElementById(idEnCours).offsetHeight);
       }
      }
      else if(droite){
       document.getElementById(idEnCours).style.width = document.getElementById(idEnCours).offsetWidth + (e.clientX - x - document.getElementById(idEnCours).offsetWidth);
       if(haut){
        document.getElementById(idEnCours).style.top = e.clientY;
        document.getElementById(idEnCours).style.height = document.getElementById(idEnCours).offsetHeight + (ytmp - e.clientY);
       }
       else if(bas){
        document.getElementById(idEnCours).style.height = document.getElementById(idEnCours).offsetHeight + (e.clientY - y - document.getElementById(idEnCours).offsetHeight);
       }
      }
      else if(haut){
       document.getElementById(idEnCours).style.top = e.clientY;
       document.getElementById(idEnCours).style.height = document.getElementById(idEnCours).offsetHeight + (ytmp - e.clientY);
      }
      else if(bas){
       document.getElementById(idEnCours).style.height = document.getElementById(idEnCours).offsetHeight + (e.clientY - y - document.getElementById(idEnCours).offsetHeight);
      }
      else{
       document.getElementById(idEnCours).style.left = e.clientX - (xinit-x);
       document.getElementById(idEnCours).style.top = e.clientY - (yinit-y);
      }
     }
     chercheCurseur(e, idEnCours);
    }
     
    function chercheCurseur(e, id){
     xtmp = document.getElementById(id).offsetLeft;
     ytmp = document.getElementById(id).offsetTop;
     // cherche le curseur adapté
     if(e.clientX >= xtmp && e.clientX <= xtmp+2){
      document.getElementById('body').style.cursor = "w-resize";
      if(e.clientY >= ytmp && e.clientY <= ytmp+2){
       document.getElementById('body').style.cursor = "nw-resize";
      }
      else if(e.clientY >= ytmp + document.getElementById(id).offsetHeight-2 && e.clientY <= ytmp + document.getElementById(id).offsetHeight){
       document.getElementById('body').style.cursor = "sw-resize";
      }
     }
     else if(e.clientX >= xtmp + document.getElementById(id).offsetWidth-2 && e.clientX <= xtmp + document.getElementById(id).offsetWidth){
      document.getElementById('body').style.cursor = "e-resize";
      if(e.clientY >= ytmp && e.clientY <= ytmp+2){
       document.getElementById('body').style.cursor = "ne-resize";
      }
      else if(e.clientY >= ytmp + document.getElementById(id).offsetHeight-2 && e.clientY <= ytmp + document.getElementById(id).offsetHeight){
       document.getElementById('body').style.cursor = "se-resize";
      }
     }
     else if(e.clientY >= ytmp && e.clientY <= ytmp+2){
      document.getElementById('body').style.cursor = "n-resize";
     }
     else if(e.clientY >= ytmp + document.getElementById(id).offsetHeight-2 && e.clientY <= ytmp + document.getElementById(id).offsetHeight){
      document.getElementById('body').style.cursor = "s-resize";
     }
     else{
      document.getElementById('body').style.cursor = "move";
     }
    }
     
    function fin(e){
     initier = false;
     gauche = false;
     droite = false;
     haut = false;
     bas = false;
      xtmp = document.getElementById(idEnCours).offsetLeft;
      ytmp = document.getElementById(idEnCours).offsetTop;
     
    }
     
    function reset(){
     document.getElementById('body').style.cursor = "auto";
    }
     
    </script>
    </head>
    <body id="body" onmousemove="bouge(event);" onmouseup="fin(event);">
    <div id="dim1" onmouseout="reset();" onmousedown="init(event, this);">bla
    <input type="text" value="dim1hidden" id="dim1hidden"></input>
    </div>
    <div id="dim2" onmouseout="reset();" onmousedown="init(event, 'dim2');">bla
    <input type="text" value="dim2hidden" id="dim2hidden"></input></div>
     
    </body>
     
    </html>
    Faites le test sous IE et ensuite sous FF, vous allez voir que lorsque on agrandis le div par la gauche, le div s'aggrandis beacoup trop ce qui fait que le côté droit du div "s'enfuit"...

    Je ne vois vraiment pas... on dirait que FF ne sais pas compter...
    C'est la lgine 86 qui assure l'agrandissement du div par la gauche...

    Si qqun a une idée... merci d'avance!!

  2. #2
    Membre averti Avatar de Sacha999
    Inscrit en
    Mars 2007
    Messages
    294
    Détails du profil
    Informations personnelles :
    Âge : 44

    Informations forums :
    Inscription : Mars 2007
    Messages : 294
    Points : 350
    Points
    350
    Par défaut
    C'est bizarre, on dirait que sous FF, il y a une desynchronisation. Si tu deplace vite ta souris, l'effet sera atténué mais si tu bouge vite la souris, c'est multiplié. C'est marrant que sous IE y'a pas de soucis, faudrait voir si tu utilises les bonnes fonction, je connais pas trop perso

Discussions similaires

  1. Différence sous IE7 et Firefox
    Par Pierre1111 dans le forum Mise en page CSS
    Réponses: 7
    Dernier message: 03/03/2009, 15h33
  2. Disposition différence sous ie7 et FF3
    Par mc_toma dans le forum Mise en page CSS
    Réponses: 8
    Dernier message: 18/08/2008, 13h24
  3. Différences aperçu avt impression / impression sous mozilla
    Par needSomeHelp dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 13/01/2006, 15h45
  4. Différence de margin avec les li sous FF et IE
    Par Death83 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 10/12/2005, 15h38
  5. [Linux]différence de code de windows vers unix sous eclipse
    Par skywalker3 dans le forum Eclipse Java
    Réponses: 6
    Dernier message: 05/01/2005, 15h11

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