web-dev-qa-db-fra.com

CSS 3 slide-in de la transition gauche

Existe-t-il une solution multi-navigateurs pour produire une transition par insertion avec CSS uniquement, sans JavaScript? Vous trouverez ci-dessous un exemple de contenu HTML:

<div>
    <img id="slide" src="http://.../img.jpg />
</div>
137
Gimmy

Vous pouvez utiliser des transitions CSS3 ou peut-être des animations CSS3 pour faire glisser un élément.

Pour le support du navigateur: http://caniuse.com/

J'ai fait deux exemples rapides juste pour vous montrer comment je veux dire.

Transition CSS (en survol)

Demo One

Code pertinent

.wrapper:hover #slide {
    transition: 1s;
    left: 0;
}

Dans ce cas, je fais simplement passer la position de left: -100px; à 0; avec un 1. durée. Il est également possible de déplacer l'élément à l'aide de transform: translate();

animation CSS

Demo Two

#slide {
    position: absolute;
    left: -100px;
    width: 100px;
    height: 100px;
    background: blue;
    -webkit-animation: slide 0.5s forwards;
    -webkit-animation-delay: 2s;
    animation: slide 0.5s forwards;
    animation-delay: 2s;
}

@-webkit-keyframes slide {
    100% { left: 0; }
}

@keyframes slide {
    100% { left: 0; }
}

Même principe que ci-dessus (Demo One), mais l'animation démarre automatiquement après 2s. Dans ce cas, j'ai défini animation-fill-mode sur forwards, ce qui conservera l'état final, en maintenant la div visible à la fin de l'animation.

Comme je le disais, deux exemples rapides pour vous montrer comment faire.

EDIT: Pour plus de détails En ce qui concerne les animations et transitions CSS, voir:

Animations

https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Using_CSS_animations

Transitions

https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Using_CSS_transitions

J'espère que cela a aidé.

238

Utilisez CSS3 2D transform pour éviter les problèmes de performances (mobile)

Un écueil courant consiste à animer les propriétés left/top/right/bottom au lieu d'utiliser transformation-css pour obtenir le même effet . Pour diverses raisons, la sémantique des transformations facilite leur déchargement, mais left/top/right/bottom sont beaucoup plus difficiles.

Source: Réseau de développeurs Mozilla (MDN)


Démo:

var $slider = document.getElementById('slider');
var $toggle = document.getElementById('toggle');

$toggle.addEventListener('click', function() {
    var isOpen = $slider.classList.contains('slide-in');

    $slider.setAttribute('class', isOpen ? 'slide-out' : 'slide-in');
});
#slider {
    position: absolute;
    width: 100px;
    height: 100px;
    background: blue;
    transform: translateX(-100%);
    -webkit-transform: translateX(-100%);
}

.slide-in {
    animation: slide-in 0.5s forwards;
    -webkit-animation: slide-in 0.5s forwards;
}

.slide-out {
    animation: slide-out 0.5s forwards;
    -webkit-animation: slide-out 0.5s forwards;
}
    
@keyframes slide-in {
    100% { transform: translateX(0%); }
}

@-webkit-keyframes slide-in {
    100% { -webkit-transform: translateX(0%); }
}
    
@keyframes slide-out {
    0% { transform: translateX(0%); }
    100% { transform: translateX(-100%); }
}

@-webkit-keyframes slide-out {
    0% { -webkit-transform: translateX(0%); }
    100% { -webkit-transform: translateX(-100%); }
}
<div id="slider" class="slide-in">
    <ul>
        <li>Lorem</li>
        <li>Ipsum</li>
        <li>Dolor</li>
    </ul>
</div>

<button id="toggle" style="position:absolute; top: 120px;">Toggle</button>
131
mate64

Voici une autre solution utilisant la transformation css (pour des raisons de performances sur les mobiles, voir la réponse de @ mate64) sans avoir à utiliser des animations et des images clés.

J'ai créé deux versions à insérer de chaque côté.

$('#toggle').click(function() {
  $('.slide-in').toggleClass('show');
});
.slide-in {
  z-index: 10; /* to position it in front of the other content */
  position: absolute;
  overflow: hidden; /* to prevent scrollbar appearing */
}

.slide-in.from-left {
  left: 0;
}

.slide-in.from-right {
  right: 0;
}

.slide-in-content {
  padding: 5px 20px;
  background: #eee;
  transition: all .5s ease; /* our Nice transition */
}

.slide-in.from-left .slide-in-content {
  transform: translateX(-100%);
  -webkit-transform: translateX(-100%);
}

.slide-in.from-right .slide-in-content {
  transform: translateX(100%);
  -webkit-transform: translateX(100%);
}

.slide-in.show .slide-in-content {
  transform: translateX(0);
  -webkit-transform: translateX(0);
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="slide-in from-left">
  <div class="slide-in-content">
    <ul>
      <li>Lorem</li>
      <li>Ipsum</li>
      <li>Dolor</li>
    </ul>
  </div>
</div>

<div class="slide-in from-right">
  <div class="slide-in-content">
    <ul>
      <li>One</li>
      <li>Two</li>
      <li>Three</li>
    </ul>
  </div>
</div>

<button id="toggle" style="position:absolute; top: 120px;">Toggle</button>
11
w.stoettinger

UTILISEZ CECI POUR DROIT AU GLISSEMENT GAUCHE:

HTML:

   <div class="nav ">
       <ul>
        <li><a href="#">HOME</a></li>
        <li><a href="#">ABOUT</a></li>
        <li><a href="#">SERVICES</a></li>
        <li><a href="#">CONTACT</a></li>
       </ul>
   </div>

CSS:

/*nav*/
.nav{
    position: fixed;
    right:0;
    top: 70px;
    width: 250px;
    height: calc(100vh - 70px);
    background-color: #333;
    transform: translateX(100%);
    transition: transform 0.3s ease-in-out;

}
.nav-view{
    transform: translateX(0);
}
.nav ul{
    margin: 0;
    padding: 0;
}
.nav ul li{
    margin: 0;
    padding: 0;
    list-style-type: none;
}
.nav ul li a{
    color: #fff;
    display: block;
    padding: 10px;
    border-bottom: solid 1px rgba(255,255,255,0.4);
    text-decoration: none;
}

JS:

  $(document).ready(function(){
  $('a#click-a').click(function(){
    $('.nav').toggleClass('nav-view');
  });
});

DOSSIER DE TUTORIAL ET DE SOURCE: [REGARDER CETTE VIDÉO] [1]

DEMO: http://www.themeswild.com/read/slide-navigation-left-to-right

4
Sharavnan Kv