Skip welcome & menu and move to editor
Welcome to JS Bin
Load cached copy from
 
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width">
  <title>Scroll snapping - working</title>
</head>
<body>
  
  <div class="carousel" id="carousel">
    <div style="background-color: red;" id="toggle1">
      1
    </div>
    <div style="background-color: green;">
      2
    </div>
    <div style="background-color: yellow;">
      3
    </div>
    <div style="background-color: blue;">
      4
    </div>
    <div style="background-color: pink;" id="toggle2">
      5
    </div>
    <div style="background-color: lime;">
      6
    </div>
  </div>
  <button id="one">Toggle1</button>
  <button id="two">Toggle5</button>
</body>
</html>
 
one.addEventListener('click', function() {
  if (toggle1.parentNode.hasAttribute('show')) {
    toggle1.parentNode.removeAttribute('show');
  } else {
    toggle1.parentNode.setAttribute('show', '');
  }
});
two.addEventListener('click', function() {
  if (toggle2.parentNode.hasAttribute('show')) {
    toggle2.parentNode.removeAttribute('show');
  } else {
    toggle2.parentNode.setAttribute('show', '');
  }
});
function init() {
  var slides = document.querySelectorAll('.carousel > div');
  var wrappers = [];
  var container = document.createElement('div');
  var dummy = document.createElement('div');
  dummy.classList.add('carousel-start-marker');
  container.appendChild(dummy);
  [].forEach.call(slides, function(slide) {
    var wrapper = document.createElement('div');
    wrapper.appendChild(slide);
    wrappers.push(wrapper);
    container.appendChild(wrapper);
    //wrapper.style.webkitScrollSnapCoordinate = '0 0';
  });
  var dummy2 = document.createElement('div');
  dummy2.classList.add('carousel-end-marker');
  container.appendChild(dummy2);
  carousel.appendChild(container);
  container.classList.add('slides-container');
  wrappers.forEach(function(wrapper) {
    wrapper.classList.add('slide-item');
    //wrapper.style.webkitScrollSnapCoordinate = '0 0';
  });
  
  wrappers[0].setAttribute('show', '');
  wrappers[1].setAttribute('show', '');
  //container.style.webkitScrollSnapType='mandatory';
}
init();
Output

You can jump to the latest bin by adding /latest to your URL

Dismiss x
public
Bin info
sriramkrish85pro
0viewers