水平平滑动量滚动

Dav*_*ins 8 javascript horizontal-scrolling smooth-scrolling

问题:我需要对这个布局应用一些鼠标滚轮平滑水平滚动:https : //jsfiddle.net/38qLnzkh/

替代方案:我发现这个脚本完全符合我的要求,但它似乎只能垂直工作:Butter.js。如果你能让它水平工作,它可能会解决我所有的问题。

重要的:

1.应根据屏幕宽度和触摸设备禁用脚本。

2.它应该像你在小提琴中看到的那样在所有东西的顶部容纳一个菜单。

先感谢您。

编辑: 如果不清楚我需要什么,这里有两个我正在寻找的效果示例:

https://nemesiscorporation.com/

https://www.tentwenty.me/about-us


我的布局:

HTML:

<main class="outer-wrapper">
    <div class="wrapper">
        <article class="section" id="a"><h2>01</h2></article>
        <article class="section" id="b"><h2>02</h2></article>
        <article class="section" id="c"><h2>03</h2></article>
        <article class="section" id="d"><h2>04</h2></article>
        <article class="section" id="e"><h2>05</h2></article>
        <article class="section" id="f"><h2>06</h2></article>
    </div>
</main>
Run Code Online (Sandbox Code Playgroud)

CSS:

.outer-wrapper {
  width: auto;
  height: 100vw;
  transform: rotate(-90deg) translateX(-100vh);
  transform-origin: top left;
  overflow-y: scroll;
  overflow-x: hidden;
  position: absolute;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
::-webkit-scrollbar {
  display: none;
}

.wrapper {
  display: flex;
  flex-direction: row;
  width: auto;
  transform: rotate(90deg) translateY(-100vh);
  transform-origin: top left;
    margin: 0;
  padding: 0;
}

.section {
    color: #000;
  width: 100vw;
  height: 100vh;
}
Run Code Online (Sandbox Code Playgroud)

Cri*_*nte 8

我在github上发布了一个可以轻松解决这个问题的API,下面你会找到代码来做你想做的。

与你的相比,我刚刚<script>在 HTML 中添加了 js 代码和。

如果您想了解更多信息,可以在此处找到文档

编辑
由于需求发生了一些变化并且 API 已经更新,我修改了下面的示例,使其更适合问题。

答案的主要变化:

  • 现在 js 在一个init()名为的方法中onload
  • 已修改 css 样式(transform:rotate制动大部分滚动 API)
  • 添加了对导航栏平滑滚动的支持
  • 滚动量现在取决于用户实际滚动鼠标滚轮的程度

2021 年更新
随着 3.0 更新,这个解决方案变得有点不准确,所以我更新了代码,以便任何未来的读者都能得到正确的答案。

/* NEW ANSWER */
function init() {
    /*
     * Variables preparation
     */
    let yourWrapperElement = document.getElementsByClassName("outer-wrapper")[0];
    let whateverEaseFunctionYouWant = remaningScrollDistance => { return remaningScrollDistance / 15 + 1 };

    //Added support for navbar menu's smooth scrolling
    uss.hrefSetup();

    /*
     * As you asked for, we only apply the custom scrolling for desktop devices
     * by using the "wheel" event instead of the "scroll" or "touchmove" events.
     */
    yourWrapperElement.addEventListener("wheel", event => {
      /*
       * We want to overwrite the default scrolling behaviour
       * of your outer-wrapper component.
       */
      event.preventDefault();
      event.stopPropagation();
      uss.scrollXBy(event.deltaY, yourWrapperElement, null, false);             
    }, {passive:false});

    /*
     * We apply a the custom ease function
     * which will be used whenever our component is scrolled by the API
     */
    uss.setXStepLengthCalculator(whateverEaseFunctionYouWant, yourWrapperElement);
}


/* OLD ANSWER
function init() {
     //
     // Variables preparation
     //
    let yourWrapperElement = document.getElementsByClassName("outer-wrapper")[0];
    let minScrollDistance = window.innerWidth / 5; //Adjust the scroll sensitivity as you like
    let minScrollDistanceRaw = minScrollDistance / 3;
    let whateverEaseFunctionYouWant = remaningScrollDistance => { return remaningScrollDistance / 15 + 1 };
    let previousScrollDirection = undefined;
    let currentScrollDirection = undefined;

    //Added support for navbar menu's smooth scrolling
    uss.hrefSetup();

     //
     // As you asked for, we only apply the custom scrolling for desktop devices
     // by using the "wheel" event instead of the "scroll" or "touchmove" events.
     //
    yourWrapperElement.addEventListener("wheel", event => {
       //
       // We want to overwrite the default scrolling behaviour
       // of your outer-wrapper component.
       //
      event.preventDefault();
      event.stopPropagation();
       //
       // In this new section we check if the scrolling has changed currentScrollDirection
       // and if so we stop the scrolling on the exact spot the user decided
       //
      currentScrollDirection = Math.sign(event.deltaY);
      if(currentScrollDirection !== previousScrollDirection) {
        previousScrollDirection = currentScrollDirection;
        uss.stopScrollingX(yourWrapperElement);
      }

      //The scrolling amount is now influenced by how much the user scrolls
      if(Math.abs(event.deltaY) >= 100) //For browsers that use multiples of 100 as deltaY
          uss.scrollXBy(event.deltaY / 100 * minScrollDistance, yourWrapperElement, null, true);
      else //For the browsers that use the raw scroll input as deltaY
          uss.scrollXBy(event.deltaY * minScrollDistanceRaw, yourWrapperElement, null, true);     
    }, {passive:false});

     //
     // We apply a the custom ease function
     // which will be used whenever our component is scrolled by the API
     //
    uss.setXStepLengthCalculator(whateverEaseFunctionYouWant, yourWrapperElement);
}*/
Run Code Online (Sandbox Code Playgroud)
body {
  margin: 0;
  padding: 0;
}

.outer-wrapper {
  width: auto;
  height: 100vh; /*  Changed to vh */
  width: 100vw; /* Added */
  /*transform: rotate(-90deg) translateX(-100vh); ROTATING containers brakes 90% of scrolling APIs
  transform-origin: top left;*/
  overflow-y: scroll;
  overflow-x: hidden;
  position: absolute;
  scrollbar-width: none;
  -ms-overflow-style: none;
  /*scroll-behavior: smooth; ISN'T NEEDED FOR MY API */
}

::-webkit-scrollbar {
  display: none;
}

.wrapper {
  display: flex;
  flex-direction: row;
  /*width: auto; NOT NEEDED IF WE USE FLEX-SHRINK 0
  transform: rotate(90deg) translateY(-100vh); ROTATING containers brakes 90% of scrolling APIs
  transform-origin: top left;*/
  margin: 0; /* not really needed */
  padding: 0; /* not really needed */
}

.section {
  color: #000;
  flex-shrink: 0; /* ADDED insted of the width/height of the wrapper */
  width: 100vw;
  height: 100vh;
}

#a { background-color: #ccc; }
#b { background-color: #fff; }
#c { background-color: #ccc; }
#d { background-color: #fff; }
#e { background-color: #ccc; }
#f { background-color: #fff; }


h2 {
  text-align: center;
  font-size: 200px;
  margin: 0;
}



/* MENU  _________________________ */



.logo {
  float: left;
}

nav {
  width: 100%;
}

/* HEADER */

header {
  float: left;
  width: 100%;
  position: absolute;
  z-index: 9999;
}


/* HEADER LARGE */

header.large {
  height: 50px;
}

header.large .logo {
  width: 225px;
  height: 50px;
  margin: 20px 0 0 20px;
  background: url('../images/logo-fireqa-green-500px.png');
  background-repeat: no-repeat;
  background-size: contain;

  transition: 0.7s all;
  -moz-transition: 0.7s all;
  -webkit-transition: 0.7s all;
  -o-transition: 0.7s all;
}


/* UNORDERED LIST */

header.large ul {
  list-style: none;
  float: right;
  margin-right: 25px;
}
header.small ul {
  list-style: none;
  float: right;
  margin: 0;
}

header.large li {
  display: inline;
  float: left;
  list-style-position: inside;
  height: 50px;
  -webkit-transition: all ease 0.3s;
  -moz-transition: all ease 0.3s;
  transition: all 0.3s ease-in-out;
}


header.large li a {
  display: block;
  padding: 20px;
  color: #0E6245;
  text-decoration: none;
  font-family: 'Montserrat', 'arial', sans-serif;
  font-weight: 600 !important;
  letter-spacing: -1px;
  font-size: 25px;

  background-image: linear-gradient(#0E6245, #0E6245);
  background-position: 50% 80%;
  background-repeat: no-repeat;
  background-size: 0% 4px;

  -moz-transition: all 0.3s ease-in-out 0s;
  -ms-transition: all 0.3s ease-in-out 0s;
  -o-transition: all 0.3s ease-in-out 0s;
  -webkit-transition: all 0.3s ease-in-out 0s;
  transition: all 0.3s ease-in-out 0s;
}

header.large li a:hover, a:focus {
  background-size: 60% 4px;
}
Run Code Online (Sandbox Code Playgroud)
<script src = "https://raw.githack.com/CristianDavideConte/universalSmoothScroll/master/js/universalsmoothscroll-min.js"></script>
<!--
<script src = "https://raw.githack.com/CristianDavideConte/universalSmoothScroll/master/js/universalsmoothscroll-old-min.js"></script> if you want to test the old answer -->
<body onload = init()>


<main class="outer-wrapper">
    <div class="wrapper">
        <article class="section" id="a"><h2>01</h2></article>
        <article class="section" id="b"><h2>02</h2></article>
        <article class="section" id="c"><h2>03</h2></article>
        <article class="section" id="d"><h2>04</h2></article>
        <article class="section" id="e"><h2>05</h2></article>
        <article class="section" id="f"><h2>06</h2></article>
    </div>
</main>


<!-- MENU _____________________ -->


<header class="large">
    <div class="container">
      <nav>
        <a><div class="logo"></div></a>
          <ul>
            <li><a href="#a">01</a></li>
            <li><a href="#b">02</a></li>
            <li><a href="#c">03</a></li>
            <li><a href="#d">04</a></li>
         </ul>
      </nav>
    </div>
  </header>

  </body>
</html>
Run Code Online (Sandbox Code Playgroud)

  • 克里斯蒂安,谢谢您花时间提出这个解决方案。它有效并且非常容易实现。这非常接近我的需要。然而,它基于scrollDistance 的事实不允许用户将页面准确地暂停在他们想要的位置。但这仍然是一个很好的解决方案,如果我找不到更好的解决方案,我肯定会使用它。非常感谢! (2认同)