我有一个水平菜单,其中包含太多元素以显示在同一个空间中。我想创建一个旋转木马效果,以便当用户单击方向箭头时,容器将水平翻译到一侧。使用jQuery的水平菜单的基本传送带
.container {
\t display: flex;
\t align-items: center;
\t height: 70px;
\t width: 420px;
border: 1px solid black;
overflow: hidden;
}
a {
\t display: flex;
\t align-items: center;
\t justify-content: center;
\t margin: 0 10px;
\t min-width: 50px;
\t min-height: 50px;
\t border: 0.1px solid tomato;
}
#left, #right {
\t border: 1px solid orange;
padding: 5px;
margin: 10px 60px;
display: inline-block;
cursor: pointer;
}
* {
\t -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box;
\t position: relative;
}
<div class="container">
\t <a>1</a>
\t <a>2</a>
\t <a>3</a>
\t <a>4</a>
\t <a>5</a>
\t <a>6</a>
\t <a>7</a>
\t <a>8</a>
\t <a>9</a>
\t <a>10</a>
\t <a>11</a>
\t <a>12</a>
\t <a>13</a>
\t <a>14</a>
</div>
<div id="left">left arrow</div>
<div id="right">right arrow</div>
我怎么能这样的动画与jQuery/CSS,使得在点击right
当前要素将转化为左侧因此,未来元素的显示?
我正在考虑使用translate(%),但div的宽度取决于容器中元素的数量,因此它会变化... 此外,如果只有2个要显示的元素,我将不得不调整动画。
我有点失落,所以任何帮助,欢迎!
请分享你试图实现自己需要的东西。 –
我试着在另一个容器上点击一个箭头时添加一个类“-webkit-transform:translate(-420px,0);'(或+ 420px),但这太不一致了,我无法在其余元素占用的空间不足420像素。我不认为这是正确的方法来解决问题 – eloism